通過電子郵件解析帶有時區(qū)的日期?我正在嘗試從電子郵件中檢索日期。起初它很容易:message = email.parser.Parser().parse(file)date = message['Date']print date我收到:'Mon, 16 Nov 2009 13:32:02 +0100'但我需要一個不錯的日期時間對象,所以我使用:datetime.strptime('Mon, 16 Nov 2009 13:32:02 +0100', '%a, %d %b %Y %H:%M:%S %Z')提升了ValueError, since %Z isn't format for +0100。但我在文檔中找不到適當?shù)臅r區(qū)格式,只有這個%Z區(qū)域。有人可以幫助我嗎?
3 回答

心有法竹
TA貢獻1866條經(jīng)驗 獲得超5個贊
email.utils
具有parsedate()
RFC 2822格式的功能,據(jù)我所知,該功能并未棄用。
>>> import email.utils>>> import time>>> import datetime>>> email.utils.parsedate('Mon, 16 Nov 2009 13:32:02 +0100')(2009, 11, 16, 13, 32, 2, 0, 1, -1)>>> time.mktime((2009, 11, 16, 13, 32, 2, 0, 1, -1))1258378322.0>>> datetime.datetime.fromtimestamp(1258378322.0)datetime.datetime(2009, 11, 16, 13, 32, 2)
但是請注意,該parsedate
方法沒有考慮時區(qū),并且time.mktime
總是期望這里提到的本地時間元組。
>>> (time.mktime(email.utils.parsedate('Mon, 16 Nov 2009 13:32:02 +0900')) ==... time.mktime(email.utils.parsedate('Mon, 16 Nov 2009 13:32:02 +0100'))True
因此,您仍然需要解析時區(qū)并考慮當?shù)貢r差:
>>> REMOTE_TIME_ZONE_OFFSET = +9 * 60 * 60>>> (time.mktime(email.utils.parsedate('Mon, 16 Nov 2009 13:32:02 +0900')) +... time.timezone - REMOTE_TIME_ZONE_OFFSET)1258410122.0

森欄
TA貢獻1810條經(jīng)驗 獲得超5個贊
用途email.utils.parsedate_tz(date)
:
msg=email.message_from_file(open(file_name))date=Nonedate_str=msg.get('date')if date_str: date_tuple=email.utils.parsedate_tz(date_str) if date_tuple: date=datetime.datetime.fromtimestamp(email.utils.mktime_tz(date_tuple))if date: ... # valid date found
添加回答
舉報
0/150
提交
取消