1

我正在尝试解析 mbox 格式的电子邮件假脱机。

我有这样做的代码:

if string.find(line, 'Date: ') == 0:                     
    try:
        when = time.mktime(time.strptime(line[6:30], "%a, %d %b %Y %H:%M:%S"))

通常它似乎工作正常,除了当 line = 'Date: Sat, 17 Apr 2004 22:29:37 -0400\n' 它似乎给出了错误的结果(22:29:03 而不是 22:29:37 )。

这是我的 pdb 跟踪:

(Pdb) p line
'Date: Sat, 17 Apr 2004 22:29:37 -0400\n'
(Pdb) p time.strptime(line[6:30], "%a, %d %b %Y %H:%M:%S")
time.struct_time(tm_year=2004, tm_mon=4, tm_mday=17, tm_hour=22, tm_min=29, tm_sec=3, tm_wday=5, tm_yday=108, tm_isdst=-1)
(Pdb)

结果似乎延迟了 34 秒。我究竟做错了什么?

4

1 回答 1

7

你把你的线切得太短了;第二个值是排他性的,不包括在内:

>>> line[6:30]
'Sat, 17 Apr 2004 22:29:3'
>>> line[6:31]
'Sat, 17 Apr 2004 22:29:37'
>>> time.strptime(line[6:31], "%a, %d %b %Y %H:%M:%S")
time.struct_time(tm_year=2004, tm_mon=4, tm_mday=17, tm_hour=22, tm_min=29, tm_sec=37, tm_wday=5, tm_yday=108, tm_isdst=-1)
于 2012-09-05T19:32:49.473 回答