Как отсортировать mongodb с пимонго - PullRequest
147 голосов
/ 13 ноября 2011

Я пытаюсь использовать функцию сортировки при запросе моего 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 ]

277 голосов
/ 13 ноября 2011

.sort(), в pymongo, принимает key и direction в качестве параметров.

Так что, если вы хотите отсортировать, скажем, id, тогда вам нужно .sort("_id", 1)

Для нескольких полей:

.sort([("field1", pymongo.ASCENDING), ("field2", pymongo.DESCENDING)])
32 голосов
/ 11 сентября 2014

Вы можете попробовать это:

db.Account.find().sort("UserName")  
db.Account.find().sort("UserName",pymongo.ASCENDING)   
db.Account.find().sort("UserName",pymongo.DESCENDING)  
13 голосов
/ 12 марта 2015

Это также работает:

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

Я использую это в своем коде, пожалуйста, прокомментируйте, если я делаю что-то не так, спасибо.

6 голосов
/ 06 февраля 2018

Почему python использует список кортежей вместо dict?

В python вы не можете гарантировать, что словарь будет интерпретирован в указанном вами порядке.

Итак, в mongo shell вы можете сделать .sort({'field1':1,'field2':1}), и интерпретатор должен отсортировать field1 на первом уровне и field 2 на втором уровне.

Если этот синтаксис использовался в python, есть шанс отсортировать field2 на первом уровне. С кортежом риска нет.

.sort([("field1",pymongo.ASCENDING), ("field2",pymongo.DESCENDING)])
1 голос
/ 27 марта 2017
.sort([("field1",pymongo.ASCENDING), ("field2",pymongo.DESCENDING)])

Python использует ключ, направление.Вы можете использовать вышеуказанный способ.

Так что в вашем случае вы можете сделать это

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