Я пытаюсь использовать функцию сортировки при запросе моего 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, но это тоже не сработало. Кто-нибудь еще заставит это работать или это ошибка.
.sort([("field1",pymongo.ASCENDING), ("field2",pymongo.DESCENDING)])
сортировать несколько полей.Вы можете попробовать это:
источник
Это также работает:
Я использую это в своем коде, пожалуйста, прокомментируйте, если я делаю что-то не так, спасибо.
источник
ASCENDING
иDESCENDING
отpymongo
. :)Почему python использует список кортежей вместо dict?
В python вы не можете гарантировать, что словарь будет интерпретирован в указанном вами порядке.
Таким образом, в оболочке mongo вы можете это сделать,
.sort({'field1':1,'field2':1})
и интерпретатор должен отсортировать field1 на первом уровне и field 2 на втором уровне.Если этот синтаксис использовался в python, есть шанс отсортировать field2 на первом уровне. С кортежом риска нет.
источник
Python использует ключ, направление. Вы можете использовать вышеуказанный способ.
Так что в вашем случае вы можете сделать это
источник
TLDR: конвейер агрегации быстрее по сравнению с обычным
.find().sort()
.Теперь переходим к реальному объяснению. Есть два способа выполнить операции сортировки в MongoDB:
.find()
и.sort()
.Как предлагают многие .find (). Sort () - самый простой способ выполнить сортировку.
Однако это медленный процесс по сравнению с конвейером агрегации.
Подходя к методу агрегации трубопроводов. Шаги для реализации простого конвейера агрегации, предназначенного для сортировки:
ПРИМЕЧАНИЕ. По моему опыту, конвейер агрегации работает немного быстрее, чем
.find().sort()
метод.Вот пример конвейера агрегации.
Попробуйте этот метод самостоятельно, сравните скорость и дайте мне знать об этом в комментариях.
Редактировать: не забудьте использовать
allowDiskUse=True
при сортировке по нескольким полям, иначе это вызовет ошибку.источник
Скажем, вы хотите отсортировать по полю «selected_on», тогда вы можете сделать так,
источник