- 我知道这是一个相当普遍的问题 . 我试图将一些查询反馈给视图 . 我've connected to my local MongoDB setup, and made a successful query - but I can' t用它生成一个json对象 .
我见过的最常见的解决方案是从pymongo导入json_util,即
import json
from pymongo import json_util
results = connection.get_collection('papayas_papaya')
results = results.find({
'identifier': '1',
})
serialized_results = [json.dumps(result, default=json_util.default, separators=(',', ':')) for result in results]
我使用pip将pymongo安装到我的Flask virtualenv中,即:
pip install pymongo
运行上面的代码时,我不断收到以下错误:
ImportError: cannot import name json_util
我可以在pymongo-2.3-py2.6.egg-info / installed-files.txt ../bson/json_util.py中看到这一行
任何人都有任何提示可以帮我弄清楚我做错了什么?
UPDATE :对此进行了进一步的研究 - 我已经成功地实现了这一点:
import pymongo
from bson.json_util import dumps
connection = pymongo.Connection("localhost", 27017)
db = connection.mydocs
def get():
cursor = db.foo.find({"name" : "bar"})
return dumps(cursor)
我遇到的一个问题是试图独立安装bson - pymongo带来bson并分别导入bson导致问题 .
感谢@Cagex指出我正确的方向
1 回答
看起来你想从bson而不是pymongo导入 . 我相信json_util最近被移到了那个模块 . http://api.mongodb.org/python/current/api/bson/json_util.html