본문 바로가기
파이썬

파이썬 pymongo로 mongodb를 정렬하는 방법

by º기록 2020. 9. 26.
반응형

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'를 배치해야한다는 링크를 다른 곳에서 찾았지만 작동하지 않았습니다. 다른 사람이 이것을 작동 시키거나 이것은 버그입니다.

 

해결 방법

 

pymongo의 .sort () key direction 을 매개 변수로 사용합니다.

따라서 id 를 기준으로 정렬하려면 .sort ( "_ id", 1)

여러 입력란의 경우 :

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

 

참조 페이지 https://stackoverflow.com/questions/8109122

 

 

반응형

댓글