用于一天结束的 django FilterSet
django FilterSet for end of day
如何使查询从 FilterSet 的开始日期和结束日期中获取正确的日期。
现在,如果您键入 start_filter_date = 2018.05.23 和 end_filter_date = 2018.05.25。那么start_filter_date=2018.05.23T00:00和end_filter_date=2018.05.25T00:00。时间占用00:00,但需要23:59?
我的 class 如下:
class TaskFilterSet(django_filters.rest_framework.FilterSet):
id = django_filters.NumberFilter(name="pk")
start_filter_date = django_filters.DateFilter(name="date_added", lookup_expr="gte")
end_filter_date = django_filters.DateFilter(name="date_added", lookup_expr="lte")
我认为最好的方法是使用 gte
和 lt
但发送结束日期 date_added + timedelta(1)
,我不使用 django 过滤器但基于 tips.html#solution-1-magic-values你可以试试:
class EndFilter(django_filters.DateFilter):
def filter(self, qs, value):
if value:
value = value + timdelta(1)
return super(EndFilter, self).filter(qs, value)
class TaskFilterSet(django_filters.rest_framework.FilterSet):
id = django_filters.NumberFilter(name="pk")
start_filter_date = django_filters.DateFilter(name="date_added", lookup_expr="gte")
end_filter_date = EndFilter(name="date_added", lookup_expr="lt")
如何使查询从 FilterSet 的开始日期和结束日期中获取正确的日期。 现在,如果您键入 start_filter_date = 2018.05.23 和 end_filter_date = 2018.05.25。那么start_filter_date=2018.05.23T00:00和end_filter_date=2018.05.25T00:00。时间占用00:00,但需要23:59?
我的 class 如下:
class TaskFilterSet(django_filters.rest_framework.FilterSet):
id = django_filters.NumberFilter(name="pk")
start_filter_date = django_filters.DateFilter(name="date_added", lookup_expr="gte")
end_filter_date = django_filters.DateFilter(name="date_added", lookup_expr="lte")
我认为最好的方法是使用 gte
和 lt
但发送结束日期 date_added + timedelta(1)
,我不使用 django 过滤器但基于 tips.html#solution-1-magic-values你可以试试:
class EndFilter(django_filters.DateFilter):
def filter(self, qs, value):
if value:
value = value + timdelta(1)
return super(EndFilter, self).filter(qs, value)
class TaskFilterSet(django_filters.rest_framework.FilterSet):
id = django_filters.NumberFilter(name="pk")
start_filter_date = django_filters.DateFilter(name="date_added", lookup_expr="gte")
end_filter_date = EndFilter(name="date_added", lookup_expr="lt")