如何用pymongo对mongodb进行sorting

我试图在查询我的mongoDB时使用sortingfunction,但是失败了。 相同的查询在MongoDB控制台中工作,但不在这里。 代码如下:

import pymongo from pymongo import Connection connection = Connection() db = connection.myDB print db.posts.count() for post in db.posts.find({}, {'entities.user_mentions.screen_name':1}).sort({u'entities.user_mentions.screen_name':1}): print post 

我得到的错误如下:

 Traceback (most recent call last): File "find_ow.py", line 7, in <module> for post in db.posts.find({}, {'entities.user_mentions.screen_name':1}).sort({'entities.user_mentions.screen_name':1},1): File "/Library/Python/2.6/site-packages/pymongo-2.0.1-py2.6-macosx-10.6-universal.egg/pymongo/cursor.py", line 430, in sort File "/Library/Python/2.6/site-packages/pymongo-2.0.1-py2.6-macosx-10.6-universal.egg/pymongo/helpers.py", line 67, in _index_document TypeError: first item in each key pair must be a string 

我在其他地方find了一个链接,说如果使用pymongo,我需要放置一个“u”的关键字,但这也不起作用。 其他人得到这个工作,或者这是一个错误。

.sort()在pymongo中,以keydirection为参数。

所以,如果你想sorting,让我们说, id然后你应该.sort("_id", 1)

对于多个领域:

 .sort([("field1", pymongo.ASCENDING), ("field2", pymongo.DESCENDING)]) 

你可以试试这个:

 db.Account.find().sort("UserName") db.Account.find().sort("UserName",pymongo.ASCENDING) db.Account.find().sort("UserName",pymongo.DESCENDING) 

这也适用:

 db.Account.find().sort('UserName', -1) db.Account.find().sort('UserName', 1) 

我在我的代码中使用这个,请评论如果我在这里做错了什么,谢谢。

 .sort([("field1",pymongo.ASCENDING), ("field2",pymongo.DESCENDING)]) 

Python使用键,方向。 你可以用上面的方法。

所以在你的情况下,你可以做到这一点

 for post in db.posts.find().sort('entities.user_mentions.screen_name',pymongo.ASCENDING): print post