pymongo로 mongodb를 정렬하는 방법
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()
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)
내 코드에서 이것을 사용하고 있습니다. 여기서 뭔가 잘못하고 있다면 의견을 말하십시오. 감사합니다.
파이썬이 대신 튜플 목록을 사용하는 이유는 무엇입니까?
파이썬에서는 사전이 선언 한 순서대로 해석 될 것이라고 보장 할 수 없습니다.
따라서 mongo shell .sort({'field1':1,'field2':1})
에서 인터프리터는 field1을 첫 번째 레벨에서 필드 2를 두 번째 레벨에서 정렬해야합니다.
이 sintax가 파이썬에서 사용 되었다면, 첫 번째 레벨에서 field2를 정렬 할 기회가 있습니다. 튜플을 사용하면 위험이 없습니다.
.sort([("field1",pymongo.ASCENDING), ("field2",pymongo.DESCENDING)])
.sort([("field1",pymongo.ASCENDING), ("field2",pymongo.DESCENDING)])
파이썬은 키, 방향을 사용합니다. 위의 방법을 사용할 수 있습니다.
그래서 당신의 경우에는 이것을 할 수 있습니다
for post in db.posts.find().sort('entities.user_mentions.screen_name',pymongo.ASCENDING):
print post
참고 URL : https://stackoverflow.com/questions/8109122/how-to-sort-mongodb-with-pymongo
'development' 카테고리의 다른 글
Bash에서 두 목록의 교차 (0) | 2020.06.11 |
---|---|
모양 xml의 테두리 (0) | 2020.06.11 |
편집기 창을 최대화하려면 어떻게합니까? (0) | 2020.06.11 |
Git에서 현재 개정판이 무엇인지 어떻게 알 수 있습니까? (0) | 2020.06.11 |
url_for ()를 사용하여 Flask에서 동적 URL 만들기 (0) | 2020.06.11 |