我正在读入一组包含日期和数字的数据文件,类似于下面的示例:
Jan-61 25.3
Feb-61 23.5
Mar-61 37.9
Apr-61 40.6我正在使用以下命令读取日期
datetime.datetime.strptime(dateVariable, "%b-%y")有两位数的年份会引起问题,因为小于70 (即纪元年份)的数字被解释为2000年而不是1900年。
编辑所有文件和更改日期格式将非常困难。有没有办法让datetime以不同的方式解释两位数的年份?
发布于 2012-07-13 14:17:45
你必须在某处画出一条粗线。例如,如果您不接受未来日期(即‘’Jun 12‘是2012年,而'Aug-12’是1912年):
dt = datetime.datetime.strptime(dateVariable, "%b-%y")
if dt > datetime.now():
dt = dt - datetime.timedelta(years=100)发布于 2013-01-09 20:06:38
对于datetime.timedelta来说,Years不是一个有效的参数(至少在Python2.7中不是),所以您实际上需要使用:
dt = datetime.datetime(dt.years - 100, dt.month, dt.day, dt.hours, dt.minutes, dt.seconds)https://stackoverflow.com/questions/11465078
复制相似问题