python - 如何使用 pymongo 对 mongodb 进行排序

标签 python mongodb pymongo

我在查询我的 mongoDB 时尝试使用排序功能,但它失败了。相同的查询在 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

我在其他地方找到了一个链接,上面说如果使用 pymongo,我需要在 key 前面放置一个“u”,但这也不起作用。其他任何人都能让它工作,或者这是一个错误。

最佳答案

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

因此,如果您想按 id 进行排序,那么您应该 .sort("_id", 1)

对于多个字段:

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

关于python - 如何使用 pymongo 对 mongodb 进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8109122/

相关文章:

python - 将 BeautifulSoup 元素解析为 Selenium

python - 当我 append 到 Python 中的列表时出现奇怪的行为

java - 如何使用 mongodb 的 morphia 更新/保存包含引用的文档?

python - 有没有办法根据条件将另一个函数(如 limit() )绑定(bind)到 pymongo 查询?

mongodb - PyMongo for MongoDB 中 find_one_and_update() 和 update_one() 之间的区别?

python - 让 iOS 应用程序与我的家庭服务器对话

python - 在 python 中保存 .dta 文件

ruby-on-rails - 如何使用 Devise on Rails 自定义注册?

spring - MongoDB $pull 数组 2 级

python - 如果我使用变量作为值,则在Python中进行Mongo查询