RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1605618
Accepted
Владос
Владос
Asked:2025-01-26 22:25:51 +0000 UTC2025-01-26 22:25:51 +0000 UTC 2025-01-26 22:25:51 +0000 UTC

如何忽略 Django 中的objects.filter 并获取所有对象?

  • 772

我正在制作一个购买汽车的网站,其中有一个发送的表格(过滤器)POST。

该模型Ads包含具有以下字段的对象:brand_id, model_id, generation_id.

问题:如果在网站的过滤器中没有选择“品牌”位置,那么将request.POST['brand']返回以下内容:('' 空字符串,因为<option value="">,所以输出可以更改)。然后就会出现这个错误:ValueError: Field 'id' expected a number but got ''. 但重点不是这个错误,我需要的是如果没有选择任何内容,那么Django 返回所有对象,也就是忽略过滤器brand_id。

注意: 不仅可以取消选择“品牌”,还可以取消选择任何字段。有必要通过选择“品牌”而不是选择“型号”来使过滤器忽略 model_id 并仅按“品牌”进行搜索。等等。还有 10 个字段(例如“品牌”和“型号”)可供搜索。如果针对每个案例都写,那就太多了。

以下是代码views.py:

context = {
           'Body': Brand.objects.all(),
           'EngineType': EngineType.objects.all(),
           'BoostType': BoostType.objects.all(),
           }

context['Ads'] = Ads.objects.filter(brand_id=request.POST['brand'],
                                    model_id=request.POST['model'],
                                    generation_id=request.POST['generation'],
                                    )

return render(request, 'ADS/main.html', context)

请帮忙。如果您对如何以完全不同(更好)的方式做到这一点有任何想法,我很乐意听取。

理论上理想的解决方案:Ads.objects.filter(brand_id=request.POST['brand'])可以传递给而不是 的参数request.POST['brand'],比如all(),但all()不能。然后就可以使用里面的函数(测试)if检查每个参数brand_id=test(request.POST['brand'])。如果此参数request.POST['brand']= ''(空字符串),则返回这个非常神奇的参数,它将取消此字段的过滤(在此示例中brand_id:)。

python
  • 2 2 个回答
  • 44 Views

2 个回答

  • Voted
  1. Best Answer
    Medvedev
    2025-01-26T23:34:38Z2025-01-26T23:34:38Z

    如果此字段在您的表单中是可选的,并且您希望返回所有为brand空的对象,那么:

    # если ничего не выбрали, то филтруем без request.POST['brand']
    if request.POST['brand'] == '': 
        ads = Ads.objects.filter(
            model_id=request.POST['model'],
            generation_id=request.POST['generation'],
        )
    else:
        ads = Ads.objects.filter(
            brand_id=request.POST['brand'],
            model_id=request.POST['model'],
            generation_id=request.POST['generation'],
        )
    
    
    context = {
        'Body': Brand.objects.all(),
        'EngineType': EngineType.objects.all(),
        'BoostType': BoostType.objects.all(),
        # мне кажется, глазам легче по коду искать конкретную переменную
        # чем непонятно в каком месте добавление нового ключ-значения
        'Ads': ads
    }
    
    return render(request, 'ADS/main.html', context)
    

    但为了以防万一,我会写,如果表单字段需要设为必填项,则<select>必须设置该属性required:

    <!-- например так -->
    <select name="brand" required>
    

    更新:

    现在已经很清楚了,您需要一个 Q 类。您可以在官方文档中详细了解其工作原理。

    逻辑是什么:

    因为你写的字段很多,超过10个,所以需要创建一个循环来检查字段是否填充。如果不这样做,将会搜索空字段。例子:

    # создаем словарь и в него передаем все ваши поля
    filter_parametr = {
        'brand': request.POST['brand'],
        'model': request.POST['model'],
        'generation': request.POST['generation'],
        # остальные ваши поля
    }
    
    

    接下来,我们创建一个循环和一个过滤器,并检查字段;如果字段已填充,则我们将其添加到过滤器中:

    filters = Q()
    
    for key, value in filter_parametr.items():
        if value:
            # распаковываем в аргументы
            filters &= Q(**{f"{key}_id": value})
    

    然后将过滤器插入到请求本身中:

    ads = Ads.objects.filter(filters)
    

    因此,将返回Ads根据填充字段进行过滤的对象。

    为了便于理解,** 以下是答案

    • 0
  2. user656458
    2025-02-01T03:43:34Z2025-02-01T03:43:34Z
    filters = {k:v for k,v in request.POST.items() if v != ''}
    
    abs = ABS.objects.filter(**filters)
    
    • 0

相关问题

  • 是否可以以某种方式自定义 QTabWidget?

  • telebot.anihelper.ApiException 错误

  • Python。检查一个数字是否是 3 的幂。输出 无

  • 解析多个响应

  • 交换两个数组的元素,以便它们的新内容也反转

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5