我有一个模型Book
,它有一个字段year_of_publishing
。用户输入年份,我想过滤Book
的集合,得到当年出版的所有书籍。
year = self.cleaned_data.get('year', SOME_DEFAULT_VALUE)
books = Book.objects.filter(year_of_publishing=year)
然而,用户可能会将year
字段留空,我想设置一些默认值,在.filter
函数中Django ORM将返回所有书籍,就像这个过滤器根本不存在一样。我应该使用什么值?我想它应该是独立于类型的,所以我可以将它用于Char、Choice和其他类型的字段。
您可以将一个空字典传递给.filter()
以返回所有结果,或者过滤所需的字段/值:
filters = {}
year = request.GET.get('year')
if year:
filters['year'] = year
books = Book.objects.filter(**filters)
您可以使用字典构建查询集:
parameters = ['year', 'foo', 'bar']
query_dict = {}
for parameter in parameters:
if self.cleaned_data.get(parameter, None):
query_dict[parameter] = self.cleaned_data.get(parameter)
books = Book.objects.filter(**query_dict)