程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 編程綜合問答 >> pymongo-用python對mongodb的查找問題

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方式訪問。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved