django QuerySet遇到的几个DateTimeField格式的查询过滤问题

我最近写了一个需求,获取用户最近一日,周,月,总的收入详情,我也是在网上找了一部分资料,然后自己实验,写完了代码,分享给大家

now = datetime.datetime.now()
	# 打印day_start之后得到的是 2019-04-16 19:16:26.150070 表示现在的前24个小时
day_start = now - datetime.timedelta(hours=23, minutes=59, seconds=59)
	# 然后我看源码 还有周,日 毫秒,微秒等等 

class timedelta(SupportsAbs[timedelta]):
    min: ClassVar[timedelta]
    max: ClassVar[timedelta]
    resolution: ClassVar[timedelta]

    if sys.version_info >= (3, 6):
        def __init__(self, days: float = ..., seconds: float = ..., microseconds: float = ...,
                     milliseconds: float = ..., minutes: float = ..., hours: float = ...,
                     weeks: float = ..., *, fold: int = ...) -> None: ...
    else:
        def __init__(self, days: float = ..., seconds: float = ..., microseconds: float = ...,
                     milliseconds: float = ..., minutes: float = ..., hours: float = ...,
                     weeks: float = ...) -> None: ...
 # 分别拿到 周 月 是得到现在的时间之前的一周和一个月  然后在queryset中 使用addtime__gte 小于等于的时间格式去过滤,就可以得到所有这个时间段的数据
week_start = now - datetime.timedelta(weeks=1)
month_start = now - datetime.timedelta(days=30)

下面是Date TimeField QuerySet查询常用的几个参数

1、lt:小于
queryset=yourobject.objects .filter(时间字段名称__lt=start)

2、lte:小于等于
queryset=yourobject.objects .filter(时间字段名称__lte=start)

3、gt:大于某个时间
now = datetime.datetime.now()
#前一天
start = now – datetime.timedelta(hours=23, minutes=59, seconds=59)

start = now+datetime.timedelta(day=-1)
queryset=MemberRole.objects .filter(时间字段名称__gt=start)

4、gte:大于等于某个时间:
queryset=MemberRole.objects .filter(时间字段名称__gte=start)

5、year:查询某年
MemberRole.objects.filter(时间字段名称__year=2005)

6、month:查询某月
MemberRole.objects.filter(时间字段名称__month=12)

7、day:某天
MemberRole.objects.filter(时间字段名称__day=3)

8、week_day:星期几
MemberRole.objects.filter(时间字段名称__week_day=2)

9、range:查询时间段
start_date = datetime.date(2005, 1, 1)
end_date = datetime.date(2005, 3, 31)

10、获取上个月第一天和最后一天

import datetime
fist = datetime.date(datetime.date.today().year,datetime.date.today().month-1,1)
last = datetime.date(datetime.date.today().year,datetime.date.today().month,1)-datetime.timedelta(1)
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值