1. ホーム
  2. python

[解決済み] pymongoでmongodbをソートする方法

2022-04-20 18:22:52

質問

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」を置く必要があるというリンクを他の場所で見つけたのですが、それもうまくいきませんでした。 どなたかうまくいった方、あるいはバグでしょうか?

解決方法は?

.sort() ピモンゴで、取る keydirection をパラメータとする。

そこで、例えば、並べ替えをしたい場合。 id であれば .sort("_id", 1)

複数フィールドの場合。

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