gpt4 book ai didi

python - Django中的自定义排序

转载 作者:IT老高 更新时间:2023-10-28 22:02:03 24 4
gpt4 key购买 nike

如何在 Django QuerySets 中定义特定的排序?

具体来说,如果我有一个像这样的 QuerySet:['a10', 'a1', 'a2'].

常规顺序(使用 Whatever.objects.order_by('someField'))会给我 ['a1', 'a10', 'a2'],而我正在寻找:['a1', 'a2', 'a10'].

定义我自己的排序技术的正确方法是什么?

最佳答案

据我所知,没有办法以这种方式指定数据库端排序,因为它过于特定于后端。您可能希望求助于老式的 Python 排序:

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

如果您发现自己经常需要这种排序,我建议您为执行排序的模型创建一个自定义 models.Manager 子类。比如:

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

关于python - Django中的自定义排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/883575/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com