web-dev-qa-db-fra.com

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?

95
KennyPowers

sort devrait ê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 cela doit être une liste est que l'ordre des arguments est important et que dicts ne sont pas classés en Python <3.6

178
georg