截断一个python datetime对象的经典方法是什么?
在这种特殊情况下,到今天为止。基本上就是将小时,分,秒,微秒设置为0。
我希望输出也是一个datetime对象,而不是字符串。
截断一个python datetime对象的经典方法是什么?
在这种特殊情况下,到今天为止。基本上就是将小时,分,秒,微秒设置为0。
我希望输出也是一个datetime对象,而不是字符串。
当前回答
这里还有另一种方式,适合一行,但不是特别优雅:
dt = datetime.datetime.fromordinal(datetime.date.today().toordinal())
其他回答
要获得与给定datetime对象对应的午夜,可以使用datetime.combine()方法:
>>> from datetime import datetime, time
>>> dt = datetime.utcnow()
>>> dt.date()
datetime.date(2015, 2, 3)
>>> datetime.combine(dt, time.min)
datetime.datetime(2015, 2, 3, 0, 0)
与.replace()方法相比,基于datetime.combine()的解决方案将继续工作,即使datetime模块引入了纳秒支持。
如果需要,tzinfo可以保留,但utc偏移量可能在午夜不同,例如,由于DST转换,因此一个简单的解决方案(设置tzinfo时间属性)可能会失败。参见如何获得给定时区的“午夜”UTC时间?
不能截断datetime对象,因为它是不可变的。
但是,这里有一种方法可以构造一个新的datetime,包含0小时、分钟、秒和微秒字段,而不丢弃原始日期或tzinfo:
newdatetime = now.replace(hour=0, minute=0, second=0, microsecond=0)
有一个用来处理日期的很棒的库:Delorean
import datetime
from delorean import Delorean
now = datetime.datetime.now()
d = Delorean(now, timezone='US/Pacific')
>>> now
datetime.datetime(2015, 3, 26, 19, 46, 40, 525703)
>>> d.truncate('second')
Delorean(datetime=2015-03-26 19:46:40-07:00, timezone='US/Pacific')
>>> d.truncate('minute')
Delorean(datetime=2015-03-26 19:46:00-07:00, timezone='US/Pacific')
>>> d.truncate('hour')
Delorean(datetime=2015-03-26 19:00:00-07:00, timezone='US/Pacific')
>>> d.truncate('day')
Delorean(datetime=2015-03-26 00:00:00-07:00, timezone='US/Pacific')
>>> d.truncate('month')
Delorean(datetime=2015-03-01 00:00:00-07:00, timezone='US/Pacific')
>>> d.truncate('year')
Delorean(datetime=2015-01-01 00:00:00-07:00, timezone='US/Pacific')
如果你想要返回datetime值:
>>> d.truncate('year').datetime
datetime.datetime(2015, 1, 1, 0, 0, tzinfo=<DstTzInfo 'US/Pacific' PDT-1 day, 17:00:00 DST>)
截断是什么意思?
您可以通过使用strftime()方法和使用适当的格式字符串来完全控制格式。
http://docs.python.org/library/datetime.html#strftime-strptime-behavior
如果你不关心时间,就用date而不是datetime。
>>> now = datetime.now()
>>> now.date()
datetime.date(2011, 3, 29)
你可以像这样更新datetime:
>>> now.replace(minute=0, hour=0, second=0, microsecond=0)
datetime.datetime(2011, 3, 29, 0, 0)