pymongo-用python对mongodb的查找问题

问题描述

用python对mongodb的查找问题

在mongodb环境下可以用find()函数,但是在python环境下用find函数返回的是一个地址呢?请问怎么用能返回数据?
mongodb下是正常的:

 > db.posts.find()
{ "_id" : ObjectId("5587bf580e3c5241da958200"), "text" : "my first blog post", "tags" : [  "mongodb",  "python",  "pymongo" ], "author" : "jim" }
{ "_id" : ObjectId("5587c04d0e3c5241da958201"), "text" : "my second posts", "author" : "mike" }

而在python下find_one可以,find()不行:

>>> import pymongo
>>> from pymongo import MongoClient
>>> client = MongoClient()
>>> client = MongoClient('localhost',27017)
>>> db = client.testdel
>>> mycol = db.mycol
>>> mycol.find_one()
{u'description': u'MongoDB is no sql database', u'tags': [u'mongodb', u'database', u'NoSQL'], u'url': u'http://www.yiibai.com', u'title': u'MongoDB Overview', u'likes': 100.0, u'_id': ObjectId('5584b5a183a7c7ad13947748'), u'by': u'tutorials point'}
>>> for post in mycol.find()
  File "<stdin>", line 1
    for post in mycol.find()
                           ^
SyntaxError: invalid syntax
>>> for post in db.mycol.find()
  File "<stdin>", line 1
    for post in db.mycol.find()
                              ^
SyntaxError: invalid syntax
>>> mycol.find()
<pymongo.cursor.Cursor object at 0xb6d7bc4c>

把错误也一块写进去了,希望不会让大家感觉混乱.为什么find_one()可以正常使用而find()就不行呢?希望老师不吝赐教.

解决方案

find返回的是对象,你不能遍历。只能用json方式访问。

解决方案二:

检查出来了,原来是我太大意,find()后面没有加冒号,应该是for post in mycol.find():

时间: 2024-10-02 03:05:39

pymongo-用python对mongodb的查找问题的相关文章

python操作mongodb根据

  本文实例讲述了python操作mongodb根据_id查询数据的实现方法.分享给大家供大家参考.具体分析如下: _id是mongodb自动生成的id,其类型为ObjectId,所以如果需要在python中通过_id查询,就需要转换类型 如果pymongo的版本号小于2.2,使用下面的语句导入ObjectId ? 1 from pymongo.objectid import ObjectId 如果pymongo的版本号大于2.2,则使用下面的语句 ? 1 from bson.objectid

python将MongoDB里的ObjectId转换为时间戳的方法_python

本文实例讲述了python将MongoDB里的ObjectId转换为时间戳的方法.分享给大家供大家参考.具体分析如下: MongoDB里的_id字段前四位是时间戳的16进制表示,通过Python可以很容易从_id中提取出时间戳来 def timestamp_from_objectid(objectid): result = 0 try: result = time.mktime(objectid.generation_time.timetuple()) except: pass return r

时间复杂度-为什么Python中dict的查找速度和list一样?

问题描述 为什么Python中dict的查找速度和list一样? 用Python写了段程序,其中一部分是在2^20个数据中的查找,可是用dict实现起来慢, 后来发现改用list后竟然和之前的速度一样,请问这可能是什么原因呢?代码在这里 (http://ask.csdn.net/questions/224028 "") 解决方案 python的dict速度python dict listpython list与dict 解决方案二: 已解决,是我弄错了.

代码- coreseek如何使用Python操纵MongoDB数据源进行检索

问题描述 coreseek如何使用Python操纵MongoDB数据源进行检索 你好,coreseek资料太少,有个问题问下,这个到底如何检索配置...我用Python可以连接数据库,但是搞不明白如何用coreseek检索,摸索几天了... 我抓取了部分数据放在MongoDB中,想用Python及coreseek实现检索数据检索 现在就就能够实现数据Python与MongoDB数据库的连接,coreseek加进来就不知道怎么做了,参照你的代码及相关方法,但是就是不知道怎么检索数据!!求指教

python连接mongodb(安装pymongo驱动)

1.wget -q http://peak.telecommunity.com/dist/ez_setup.py 2.执行ez_setup.py脚本  代码如下 复制代码 python ez_setup.py 3.sudo easy_install pymongo 下面是个小例子:  代码如下 复制代码 from pymongo import Connection import time db = Connection(host="172.16.0.91").test db.drop_

Python操作MongoDB数据库PyMongo库使用方法_python

引用PyMongo 复制代码 代码如下: >>> import pymongo 创建连接Connection 复制代码 代码如下: >>> import pymongo >>> conn = pymongo.Connection('localhost',27017) 或 复制代码 代码如下: >>> from pymongo import Connection >>> conn = Connection('local

Python 操作 MongoDB

原文 这篇文章主要介绍了使用Python脚本操作MongoDB的教程,MongoDB作为非关系型数据库得到了很大的宣传力度,而市面上的教程一般都是讲解JavaScript的脚本操作,本文则是基于Python,需要的朋友可以参考下 0.启动mongodb数据库 $ mongod.exe --dbpath D:\mongodb\data\db 1.连接数据库 MongoClient VS Connection class MongoClient(pymongo.common.BaseObject)

简单掌握Python中glob模块查找文件路径的用法_python

glob使用UNIX shell规则查找与一个模式匹配的文件名.只要程序需要查找文件系统中名字与某个模式匹配的一组文件,就可以使用这个模块. glob的模式规则与re模块使用的正则表达式不相同.glob模式遵循标准UNIX路径扩展规则.只是用几个特殊字符来实现两个不同的通配符和字符区间.模式规则要应用于文件名中的段.模式中的路径可以是相对路径或绝对路径. shell变量名和波浪线都不会扩展. 基本用法 1.glob.glob(pathname), 返回所有匹配的文件路径列表.它只有一个参数pat

Python中的二叉树查找算法模块使用指南_python

python中的二叉树模块内容: BinaryTree:非平衡二叉树  AVLTree:平衡的AVL树  RBTree:平衡的红黑树 以上是用python写的,相面的模块是用c写的,并且可以做为Cython的包. FastBinaryTree  FastAVLTree  FastRBTree 特别需要说明的是:树往往要比python内置的dict类慢一些,但是它中的所有数据都是按照某个关键词进行排序的,故在某些情况下是必须使用的. 安装和使用 安装方法 安装环境: ubuntu12.04, py