我的云服务器以这种格式记录时间:
[17/Dec/2011:09:48:49 -0600]
要将其读入Python变量,我可以说:
>>>str = '17/Dec/2011:09:48:49 -0600'
>>>import time
>>>print time.strptime(str,"%d/%b/%Y:%H:%M:%S -0600")
结果:
time.struct_time(tm_year=2011, tm-mon=12, tm=mday=17, tm_hour=9, tm_min=48, tm_sec=49, tm_wday=5, tm_yday=351, tm_isdst=-1)
或者我可以尝试
>>>mytime = time.strptime(str,"%d/%b/%Y:%H:%M:%S -0600")
>>>print mytime.tm_hour
结果:
9
-0600
做了什么?我期望它调整日期时间对象的小时值?是否使用通配符而不是硬编码-0600
?
答案 0 :(得分:9)
-0600
是格林威治标准时间(GMT)的偏移量。作为another SO question already says,time.strptime无法读取时区偏移量,但datetime.strftime
可以生成它们。
正如在the datetime
module's documentation开头所解释的那样,有两种方法可以在python中接近“时间”,天真或意识到。当你关心的只是系统内的时间 时,处理天真的时间/日期时间对象就好了(在这种情况下你可以像阿兰建议的那样去除偏移量)。当您需要将系统内的值与现实世界的时间概念进行比较时,您必须开始处理该偏移量。
easy 处理此问题的方法仅针对use python-dateutil
。它有一个parse function,它会尽力模糊地将您传入的日期字符串与多种格式匹配,并返回一个可行的日期时间实例,该实例代表了您对其意思的最佳猜测。
>>> from dateutil.parser import parse
>>> parse('17/Dec/2011:09:48:49 -0600', fuzzy=True)
datetime.datetime(2011, 12, 17, 9, 48, 49, tzinfo=tzoffset(None, -21600))
通常,让软件给出“最佳猜测”是一件坏事。在这种情况下,如果输入格式稳定,似乎是合理的。处理软件开发的时间很难,只需去购物。
答案 1 :(得分:3)
这是GMT的抵消。如果您不想要它,只需将其剥离:
>>> import time
>>> line = '17/Dec/2011:09:48:49 -0600'
>>> line = line.split(' ')[0]
>>> print time.strptime(line,"%d/%b/%Y:%H:%M:%S")
time.struct_time(tm_year=2011, tm_mon=12, tm_mday=17, tm_hour=9, tm_min=48, tm_sec=49, tm_wday=5, tm_yday=351, tm_isdst=-1)
答案 2 :(得分:1)
strptime
只是将修饰符(%d
,%b
,...)与字符串的相应段匹配,然后将匹配的字符串转换为整数。因此,在您的情况下,-0600
仅使您的格式字符串与输入字符串匹配。
如果您想按指定的偏移量调整时间,我建议使用datetime
对象。
>>>s = '17/Dec/2011:09:48:49 -0600'
>>>from datetime import datetime,timedelta
>>>mytime = datetime.strptime(s,"%d/%b/%Y:%H:%M:%S -0600")
>>>dt = timedelta(minutes=6*60) #6 hours
>>>mytime-=dt
>>>print mytime
2011-12-17 03:48:49
>>>print mytime.hour
3
另请注意,由于str
是内置的,因此通常不建议重新分配。