[Django学习]Q对象实现多字段模糊搜索

一、应用场景

假设我们现在有一个客房系统,前端界面上展示出来了所有客房的所有信息。用户通过客房的价格、面积、人数等对客房进行模糊搜索,如检索出价格在50到100元之间的客房,同时检索面积在20平方米到30平方米之间的客房,此时后端可以借助Q对象对客房进行筛选处理,并返回给前端。

二、代码部分

学习笔记以注释的形式出现

python 复制代码
from django.db.models import Q  
def searchHouse(request):

    datas = request.POST
    type = datas.get("type")
    area = datas.get("area")
    price = datas.get("money")
    people = datas.get("people")

    query = Q()
    # 使用Q对象组合多个查询条件

    type_value = int(type)
    if type_value != 0:
        query.add(Q(type=type_value-1), Q.AND)

    if area == "1":
        # 若area检索类型为"1",则为检索面积在0到15之间的客房
        query &= Q(area__range=(0, 15))
        # 给query添加上该查询语句
    elif area == "2":
        query &= Q(area__range=(15, 20))
    elif area == "3":
        query &= Q(area__range=(20, 30))
    elif area == "4":
        query &= Q(area__gte=30)

    if price == "1":
        query &= Q(price__range=(0, 50))
    elif price == "2":
        query &= Q(price__range=(50, 100))
    elif price == "3":
        query &= Q(price__range=(100, 200))
    elif price == "4":
        query &= Q(price__gte=200)

    if people == "1":
        query.add(Q(people=1), Q.AND)
    elif people == "2":
        query.add(Q(people=2), Q.AND)
    elif people == "3":
        query &= Q(people__gte=3)

    # 依照query对house表进行检索
    reses = house.objects.filter(query)

    houses = []

    for res in reses:
        a_house = {
            "id": res.id,
            "type": res.type,
            "area": res.area,
            "price": res.price,
            "people": res.people,
            "counts": res.counts,
            "status": res.status,
            "manager_phone": res.managerID.phone,
            "manager_name": res.managerID.name
        }
        houses.append(a_house)

    return JsonResponse({'data': houses}, safe=False)
相关推荐
yuhaiqun19895 分钟前
发现前端性能瓶颈的巧妙方法:建立“现象归因→分析定位→优化验证”的闭环思维
前端·经验分享·笔记·python·学习·课程设计·学习方法
Python大数据分析@7 分钟前
使用Dify搭建工作流,实现自动化商品采集分析
运维·python·自动化·网络爬虫
code tsunami7 分钟前
如何将 Helium 与 CapSolver 集成,实现无缝 CAPTCHA 自动化解决
运维·数据库·人工智能·爬虫·python·自动化
玄同7658 分钟前
Python 异常捕获与处理:从基础语法到工程化实践的万字深度指南
开发语言·人工智能·python·自然语言处理·正则表达式·nlp·知识图谱
d111111111d11 分钟前
使用STM32 HAL库配置ADC单次转换模式详解
笔记·stm32·单片机·嵌入式硬件·学习
quant_198616 分钟前
BTC 行情预警系统实战教程
开发语言·后端·python·websocket·程序人生·金融
查拉图斯特拉面条18 分钟前
JMeter JSR223后置处理器:JSON数据处理与格式转换实战指南
python·jmeter·json
·present·20 分钟前
射频网课学习第0章(绪论)
学习
DYS_房东的猫25 分钟前
学习总结笔记三:让网站“活”起来——处理静态文件、表单验证与用户登录(第3章实战版)
笔记·学习·golang
岁岁的O泡奶25 分钟前
NSSCTF_crypto_[SWPUCTF 2023 秋季新生赛]dpdp
经验分享·python·算法·密码学