繁体   English   中英

从日期时间字段中减去整数值

[英]substract integer value from datetime field

我想从datetime字段中减去一个整数值。 这里date_joineddatetime字段,age是整数字段。

views.py

def index(request):  
    profiles = profiles.objects.all()
    for profile in profiles: 
        age = person.age
        date_joined = person.date_joined
        date_of_birth = date_joined - age
        p = date_of_birth(date_of_birth = date_of_birth,activated = 1)
        p.save()

models.py

class profiles(models.Model):
    date_joined =  models.DateTimeField (max_length=1)
    age = models.IntegerField()

采用:

date_joined - (datetime.timedelta(365) * age)

date_joined减去age

请注意,这是一个很好的快捷解决方案,但不是很可靠。 考虑以下输出:

>>> datetime.datetime(2013, 12, 12) - datetime.timedelta(365) * 15
datetime.datetime(1998, 12, 16, 0, 0)

如您所见,由于leap年(实际上有366天的年份),结果是我们实际想要的日期之后的4天。 一个更强大的解决方案是:

date_joined.replace(year = date_joined.year - age)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM