web-dev-qa-db-ja.com

pymongoでmongodbをソートする方法

私は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を使用する場合、キーの前に「u」を配置する必要があるというリンクが他の場所で見つかりましたが、それも機能しませんでした。他の誰もがこれを機能させるか、これはバグです。

147
WildBill

pymongoの.sort()は、パラメーターとしてkeyおよびdirectionを取ります。

したがって、並べ替える場合は、idとし、.sort("_id", 1)を使用する必要があります。

複数のフィールドの場合:

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

これを試すことができます:

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

これも機能します:

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

私はコードでこれを使用していますが、ここで何か間違っている場合はコメントしてください、ありがとう。

13
Snehal Parmar

なぜpythonはdictの代わりにタプルのリストを使用するのですか?

pythonでは、宣言した順序で辞書が解釈されることを保証できません。

したがって、mongo Shellでは.sort({'field1':1,'field2':1})を実行でき、インタープリターは第1レベルでfield1をソートし、第2レベルでフィールド2をソートする必要があります。

このシンタックスがpythonで使用された場合、最初のレベルでfield2をソートする機会があります。 Tupleにはリスクはありません。

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

Pythonはキー、方向を使用します。上記の方法を使用できます。

あなたの場合、これを行うことができます

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