Django快速实现多个搜索框的filter过滤json数据(无需定义过滤类)

在开发项目过程中,有多个搜索框输入,每个输入有精准查询或者范围查询等

1、我想要实现如果只输入一个条件,那么只需要这一个条件查询

2、如果输入多个条件,那就多个条件一起查询

也就是查询变量是可变

Django里面用到的Entry.objects.filter()函数,大部分用的就是必须输入查询变量和指定的值

类似这样

Entry.objects.filter(field1=value1)
Entry.objects.filter(field1=value1,field2=value2,...)

如果我要满足我的需求,那么有些搜索框为空的就必须输入进去,但是数据库查询显示为空搜不到,如果我用if判断也太麻烦了,假如我有十几个搜索条件

也上网百度好多答案,有一个做法就是下载django_fitler模块,自定义过滤类这太麻烦了!!!

这时候发现有一个函数很好用,filter(**kargs)

这个就是可以先定义好过滤的数据类似json形式的数据,再直接填入fiter参数里面

下面就是我的做法,简单快捷

    # dd={"year__contains":20,"area":"上海"}
    dd={}
    print(type(dd)) #dict类型
    for key,value in data1.items():  #这里的data1是我传入进来的一个dict类型的过滤数据
        if value!='':
            dd[key]=value
        
    print(dd)
    qRes = Entry.objects.filter(**dd) #Entry就是你python项目定义的数据库类

1、上面代码里面的dd就是我经过处理后最终传入的参数,

我的前端传来data1数据,里面的数据我还要再经过一次处理,通过dict类型的key,value遍历,如果value为空,也就是某一个变量的输入框为空,那么dd就不加入这个过滤参数

2、特别注意的是,这个dd里面的定义的key-value值也可以符合Django ORM 数据库查询规则

比如我写了dd={"year__contains":20,"area":"上海"}代表year属性包含20的都需要筛选出来

contain代表包含,记得属性与那个ORM规则之间是2个_长一点

常见的ORM规则

exact:精确匹配
iexact:不区分大小写 精确匹配
contains:包含指定值
icontains:不区分大小写的包含指定值
in:某个字段的值在给定的列表中
gt:>指定值
gte:>=指定值
lt:<指定值
lte:<=指定值
startswith:以指定值开头
istartswith:不区分大小写以指定值开头
endswith:以指定值结尾
iendswith:不区分大小写以指定值结尾
range:表示在给定范围内的对象,例如:Model.objects.filter(field__range=[value1, value2])。
date:表示指定日期的对象,例如:Model.objects.filter(field__date=date(2022, 1, 1))

year 日期字段的年份

month 日期字段的月份

day 日期字段的日

isnull / isnotnull 判空

excute 不等于

Entry.objects.filter(field1__date=date(2023, 10, 30))
Entry.objects.filter(field1__in=[value1, value2]))
Entry.objects.filter(field1__range=[value1, value2])
Entry.objects.filter(tield1__isnull=True) 
其他基本都是属性__ORM=value

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Django提供了多种方法来进行多条件过滤。 一种方法是使用Q对象来构建复杂的查询条件。Q对象允许你使用"&"(与),"|"(或)和"~"(非)来构建复杂的查询表达式。例如: ``` from django.db.models import Q MyModel.objects.filter(Q(field1='value1') | Q(field2='value2')) ``` 另一种方法是使用连锁的过滤器,例如: ``` MyModel.objects.filter(field1='value1').filter(field2='value2') ``` 还可以使用 "__in" 和 "__range" 等运算符来进行多条件过滤。 ``` MyModel.objects.filter(field1__in=['value1','value2'], field2__range=[start_date, end_date]) ``` 总之,Django提供了很多种方法来进行多条件过滤,应该根据实际需求来选择使用哪种方法。 ### 回答2: Django filter多条件过滤主要是指在查询数据时,需要使用多个条件来过滤数据。这些条件可以使用“and”、“or”等逻辑运算符进行组合,从而实现更加精准且灵活的数据查询。 在Django,使用filter()方法来实现多条件过滤filter()方法接受一系列的参数,每个参数都代表一个条件,这些条件之间可以使用逗号或者“&”、“|”等逻辑运算符连接。例如,我们可以按如下方式查询符合多个条件的数据: `from myapp.models import MyModel` `results = MyModel.objects.filter(condition1=value1, condition2=value2, ...)` 在这个例子,我们通过调用filter()方法获取了一个查询集对象results,其包含满足所有条件的数据。参数condition1、condition2等都是数据的字段,value1、value2等则是对应的值。多个参数之间使用逗号或逻辑运算符组合,表示这些条件之间的关系。 如果我们需要使用“or”等逻辑运算符进行组合,可以使用Q对象来实现。Q对象可以实现更为灵活的复杂查询,它可以被组合成更复杂的查询条件,以便达到更高效的查询结果。例如,我们可以按如下方式查询符合多个条件的数据: `from django.db.models import Q` `from myapp.models import MyModel` `my_filter = Q(condition1=value1) | Q(condition2=value2) | Q(...)` `results = MyModel.objects.filter(my_filter)` 在这个例子,我们使用Q对象创建了一个包含多个条件的查询过滤器。使用“|”符号将每个查询条件连接起来,表示这些条件之间的关系。在应用过滤器时,我们只需要将查询过滤器作为参数传递给filter()方法即可。 总之,使用Django filter多条件过滤可以让我们更加精准地查询数据。通过灵活使用逗号、逻辑运算符和Q对象,我们可以组合多个查询条件,并自由地调整它们之间的关系,以便得到符合要求的数据。 ### 回答3: Django filter多条件过滤是指,在Django使用filter()函数进行多个条件的数据筛选。在Django的模型,我们通常会定义一些字段,如title、content、created_at等,而使用filter()函数可以实现多条件过滤,如where条件的联合查询。 在Django,我们通常使用__符号来连接字段和过滤器的名称,如: ``` from django.db import models class Article(models.Model): title = models.CharField(max_length=100) content = models.TextField() created_at = models.DateTimeField(auto_now_add=True) def __str__(self): return self.title ``` 在上述模型,我们定义了三个字段:title、content和created_at,我们可以使用__符号来进行多条件查询,如: ``` Article.objects.filter(title__contains='Django', content__icontains='filter', created_at__year=2020) ``` 上述代码将会筛选出所有标题包含'Django'、 内容包含'filter'、 并且创建时间在2020年的文章。 其,__contains和__icontains可以用来匹配包含特定字符串的字段值,__year和其他时间相关的过滤器可以用于匹配日期和时间。除此之外,还有许多其他过滤器和选项可供选择,如__lt、__gt、__lte以及__gte等等。 总之,使用Django filter多条件过滤功能可以高效、简洁地完成数据筛选任务,而__符号的灵活运用也是Django过滤器的一个重要特征。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值