Por lo que sé, no hay forma de especificar el orden en el lado de la base de datos de esta manera, ya que también sería específico del back-end. Es posible que desee recurrir a la buena clasificación Python pasada de moda:
class Foo(models.Model):
name = models.CharField(max_length=128)
Foo.objects.create(name='a10')
Foo.objects.create(name='a1')
Foo.objects.create(name='a2')
ordered = sorted(Foo.objects.all(), key=lambda n: (n[0], int(n[1:])))
print ordered # yields a1, a2, 10
Si ves que necesitas este tipo de clasificación mucho, lo recomiendo hacer una subclase personalizada models.Manager
para su modelo que realiza el pedido. Algo como:
class FooManager(models.Manager):
def in_a_number_order(self, *args, **kwargs):
qs = self.get_query_set().filter(*args, **kwargs)
return sorted(qs, key=lambda n: (n[0], int(n[1:])))
class Foo(models.Model):
... as before ...
objects = FooManager()
print Foo.objects.in_a_number_order()
print Foo.objects.in_a_number_order(id__in=[5, 4, 3]) # or any filtering expression
el clavo! Maravillosa respuesta, gracias! –
Recibo este error al intentar este método: \t El objeto 'Modelo' no se puede descomponer – ninja123
¿'sorted' devuelve un conjunto de interrogación? Dado que se aprobó un conjunto de preguntas, creo que sí, pero creo que también se puede convertir en una lista o algo internamente para ordenar, luego * se devuelve *. –