deyuzhi
is_thinking
2015-06-22 13:49
采纳率: 86%
浏览 7.0k

用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()就不行呢?希望老师不吝赐教.

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

3条回答 默认 最新

  • oyljerry
    oyljerry 2015-06-22 13:53
    已采纳

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

    点赞 评论
  • deyuzhi
    is_thinking 2015-06-23 02:42

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

    点赞 评论
  • weixin_44021971
    守护月亮的星星 2020-12-23 09:14

    find返回的是游标类型,可以使用下标索引,例如:cur=mycol.find(),cur[0]返回第一条文档。

    点赞 评论

相关推荐