Как сортировать 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
Я нашел ссылку в другом месте, где говорится, что мне нужно поместить " u " перед ключом, если вы используете pymongo, но это тоже не сработало. Кто - нибудь еще заставит это работать или это ошибка.
5 ответов
.sort()
, в pymongo, занимает key
и direction
как параметры.
Итак, если вы хотите отсортировать, скажем,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)
Я использую это в своем коде, пожалуйста, прокомментируйте, если я делаю что-то неправильно здесь, Спасибо.
почему python использует список кортежей вместо dict?
в python вы не можете гарантировать, что словарь будет интерпретироваться в указанном Вами порядке.
Итак, в Mongo shell вы можете сделать .sort({'field1':1,'field2':1})
и интерпретатор должен сортировать поле 1 на первом уровне и поле 2 на втором уровне.
Если этот синтакс использовался в python, есть шанс отсортировать field2 на первом уровне. С tuple нет никакого риска.
.sort([("field1",pymongo.ASCENDING), ("field2",pymongo.DESCENDING)])
.sort([("field1",pymongo.ASCENDING), ("field2",pymongo.DESCENDING)])
Python использует ключ,направление. Вы можете использовать вышеуказанный способ.
Так что в вашем случае вы можете сделать это
for post in db.posts.find().sort('entities.user_mentions.screen_name',pymongo.ASCENDING):
print post