要对来自不同类的列表按照一个字段进行排序,我们可以使用Python的内置函数sorted() 以及Django的queryset API 。我们需要先将这些列表组合成一个列表,然后再按照指定字段排序。下面是代码示例:
假设我们有两个类,一个是Book类,一个是Magazine类,两者都有一个字段为pub_date,则我们可以使用以下代码片段进行排序:
from operator import attrgetter
books = Book.objects.all()
magazines = Magazine.objects.all()
#将两个queryset组合成一个list
items = list(books) + list(magazines)
#按照pub_date进行排序
sorted_items = sorted(items, key=attrgetter('pub_date'))
在上面的代码中,我们使用了Python中的attrgetter()函数来获取每个项的pub_date属性,并按照该属性进行排序。最后,我们可以通过sorted_items列表来访问已排序的项。
当然,如果您使用的是Django 2.0及更高版本的话,您也可以使用chain()函数将两个querysets组合成单个queryset,例如:
from itertools import chain
items = list(chain(books, magazines))
sorted_items = items.order_by('pub_date')
这种方法的优点是能够在数据库层面上对组合的查询集进行排序,从而提升性能。