首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何使用pymongo对mongodb进行排序

如何使用pymongo对mongodb进行排序
EN

Stack Overflow用户
提问于 2011-11-13 10:13:59
回答 8查看 175K关注 0票数 192

我试图在查询mongoDB时使用排序功能,但失败了。相同的查询在MongoDB控制台中可用,但在这里不行。代码如下:

代码语言:javascript
复制
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

我得到的错误如下:

代码语言:javascript
复制
Traceback (most recent call last):
  File "find_ow.py", line 7, in 
    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,我需要在键前面放一个'u‘,但这也不起作用。其他任何人让它工作,或者这是一个bug。

EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2011-11-13 10:22:39

.sort(),在pymongo,采取keydirection作为参数。

所以如果你想排序,比方说,id那么你应该.sort("_id", 1)

对于多个字段:

代码语言:js
复制
.sort([("field1", pymongo.ASCENDING), ("field2", pymongo.DESCENDING)])
票数 354
EN

Stack Overflow用户

发布于 2014-09-11 15:16:22

你可以试试这个:

代码语言:javascript
复制
db.Account.find().sort("UserName")  
db.Account.find().sort("UserName",pymongo.ASCENDING)   
db.Account.find().sort("UserName",pymongo.DESCENDING)
票数 40
EN

Stack Overflow用户

发布于 2015-03-12 19:04:48

这也是可行的:

代码语言:javascript
复制
db.Account.find().sort('UserName', -1)
db.Account.find().sort('UserName', 1)

我在我的代码中使用了这个,如果我在这里做错了什么,请发表意见,谢谢。

票数 22
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8109122

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档