5
我已經看到有關使用python通過IMAP加載電子郵件的搜索,然後對結果中的每個消息ID執行查詢。我想通過一次性提取所有東西來加快速度。一次提取多個IMAP消息
我已經看到有關使用python通過IMAP加載電子郵件的搜索,然後對結果中的每個消息ID執行查詢。我想通過一次性提取所有東西來加快速度。一次提取多個IMAP消息
RFC 3501說fetch需要一個序列集,但我沒有看到它的定義,並且該示例使用範圍形式(2:4 =消息2,3和4)。我發現一個以逗號分隔的ID列表起作用。在python與imaplib,我有這樣的東西:
status, email_ids = con.search(None, query)
if status != 'OK':
raise Exception("Error running imap search for spinvox messages: "
"%s" % status)
fetch_ids = ','.join(email_ids[0].split())
status, data = con.fetch(fetch_ids, '(RFC822.HEADER BODY.PEEK[1])')
if status != 'OK':
raise Exception("Error running imap fetch for spinvox message: "
"%s" % status)
for i in range(len(email_ids[0].split())):
header_msg = email.message_from_string(data[i * 3 + 0][1])
subject = header_msg['Subject'],
date = header_msg['Date'],
body = data[i * 3 + 1][1] # includes some mime multipart junk
你可以試試這個獲取所有郵件的頭信息在1轉到服務器。
import imaplib
import email
obj = imaplib.IMAP4_SSL('imap.gmail.com', 993)
obj.login('username', 'password')
obj.select('folder_name')
resp,data = obj.uid('FETCH', '1:*' , '(RFC822.HEADER)')
messages = [data[i][1].strip() + "\r\nSize:" + data[i][0].split()[4] + "\r\nUID:" + data[i][0].split()[2] for i in xrange(0, len(data), 2)]
for msg in messages:
msg_str = email.message_from_string(msg)
message_id = msg_str.get('Message-ID')
我想做一個搜索,然後在一次操作中獲取所有生成的消息。除非有人在我不注意的時候增加了新的物理法,我想我會沒事的。 – 2010-08-27 17:43:38