gpt4 book ai didi

python - Django 管理员 : search by date with url parameters

转载 作者:太空宇宙 更新时间:2023-11-03 14:22:21 24 4
gpt4 key购买 nike

我在 Django 1.11 中定义了一个这样的模型:

class MyModel(Models.Model):
... some fields...

created_date = models.DateTimeField() #YYYY-MM-DD h:m:s

现在我希望能够在模板中按日期搜索 myModel。为此,我扩展了change_list,一切正常。

我的问题是:我必须做什么才能检索具有特定创建日期的对象?

假设您想要在 2017 年 12 月 13 日创建的元素。如果我进入 shell,我可以通过以下方式实现:

MyModel.objects.filter(created_date__date='2017-12-13')

一切正常,我得到了数据。但为什么 __date 运算符在 URL 中不起作用?如果我将 __date 运算符放在 url 中,如下所示:

127.0.0.1:8000/admin/.../?created_date__date=2017-12-13

我收到错误:/?e=1

所以我使用 __lte 和 __gte 运算符测试了另一种方法。就像之前你想要在 2017-12-13 创建对象一样,所以我以这种方式组合了 __lte 和 __gte 运算符:

MyModel.objects.filter(created_date__gte='2017-12-13', created_date__lte='2017-12-13')

但在这种情况下,我得到一个空的查询集。也可以这样:

127.0.0.1:8000/admin/.../?created_date__gte=2017-12-13&created_date__lte=2017-12-13

所以,我的问题:

  1. 为什么 __lte 和 __gte 运算符可以用作 URL 参数,而 __date 则不能(我得到/?e=1)?我已经用其他日期进行了测试,没有任何变化。
  2. 如何获取特定的created_date对象?

最佳答案

如果你想在 django admin 中使用搜索功能,你应该在 ModelAdmin 中添加 search_fields

我不太了解您的模型管理员(因为您没有上传它)。但如果您只将模型注册到管理员,请尝试使用 ModelAdmin

    from django.contrib import admin

from Myapp.models import MyModel


@admin.register(MyModel)
class MyModelAdmin(admin.ModelAdmin):
# you can set so many things in admin. please check django doc
...
# be aware it should be tuple. If you have only one, please add comma
search_fields = ('created_at',)

然后您可以在管理页面中看到搜索输入。如果您通过 2017-12-18 进行搜索(或者仅使用 20172017-09 也可以),您可以在以下位置获取搜索 get 参数:您的网址(例如 admin/.../?q=2017-09-29)

现在您可以在管理中使用该网址。

黑客快乐!

关于python - Django 管理员 : search by date with url parameters,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47856591/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com