微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用预定义选项跨多个模型字段的 Django 过滤器

如何解决使用预定义选项跨多个模型字段的 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_choicesQ(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 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?