129 votes

Utilisation de .sort avec PyMongo

Avec PyMongo, lorsque j'essaie de récupérer des objets triés par leurs champs "nombre" et "date" comme ceci :

db.test.find({"number": {"$gt": 1}}).sort({"number": 1, "date": -1})

Je reçois cette erreur :

TypeError: if no direction is specified, key_or_list must be an instance of list

Quel est le problème avec ma requête de tri ?

235voto

georg Points 52691

sort doit être une liste de paires clé-direction, c'est-à-dire

db.test.find({"number": {"$gt": 1}}).sort([("number", 1), ("date", -1)])

La raison pour laquelle il doit s'agir d'une liste est que l'ordre des arguments a de l'importance. dict ne sont pas ordonnés dans Python < 3.6

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X