如何解决使用预定义选项跨多个模型字段的 Django 过滤器
我正在尝试使用过滤器之前定义的选项过滤模型。
store_choices = (
('harveynichols','Harvey Nichols'),('houSEOffraser','House of Fraser'),('selfridges','Selfridges'),('lookfantastic','LOOKFANTASTIC'),('superdrug','Superdrug'),('boots','Boots'),('allbeauty','allbeauty'),('asos','asos'),)
class ProductFilter(django_filters.FilterSet):
store = django_filters.MultipleChoiceFilter(choices=store_choices)
brand = django_filters.MultipleChoiceFilter(choices=brand_choices)
price = django_filters.RangeFilter()
class Meta:
model = Product
fields = ['store','brand','price']
def store_checks(self,queryset,name,store_choices):
return Product.objects.filter(
Q(store__icontains=store_choices) | Q(storehn__icontains=store_choices) | Q(storehof__icontains=store_choices) | Q(
storesf__icontains=store_choices)
| Q(storelf__icontains=store_choices) | Q(storesd__icontains=store_choices) | Q(storeboots__icontains=store_choices)
| Q(storeab__icontains=store_choices) | Q(storea__icontains=store_choices)
)
我的产品模型,有很多字段是:
class Product(models.Model):
name = models.CharField(max_length=200)
price = models.DecimalField(max_digits=6,decimal_places=2)
availability = models.BooleanField(default=True,null=True,blank=True)
store = models.TextField(max_length=200)
brand = models.TextField(max_length=200)
hyperlink = models.TextField(max_length=300)
finalimagelink = models.TextField(max_length=300)
storehn = models.TextField(max_length=200,blank=True)
storehof = models.TextField(max_length=200,blank=True)
storesf = models.TextField(max_length=200,blank=True)
storelf = models.TextField(max_length=200,blank=True)
storesd = models.TextField(max_length=200,blank=True)
storeboots = models.TextField(max_length=200,blank=True)
storeab = models.TextField(max_length=200,blank=True)
storea = models.TextField(max_length=200,blank=True)
这不起作用并且不返回任何产品,我不确定用什么变量代替 store_choices
和 Q(XXX__icontains = )
。任何帮助将不胜感激
解决方法
我猜问题是没有使用方法 store_checks
。这应该正确使用您的方法:
class ProductFilter(django_filters.FilterSet):
store = django_filters.MultipleChoiceFilter(choices=store_choices,method='store_checks')
最好使用 queryset
而不是创建一个新的:
def store_checks(self,queryset,name,store_choices):
return queryset.filter(
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。