我看到的有关使用Python加载电子邮件加载电子邮件的示例进行搜索,然后在结果中为每个消息ID进行查询。我想一次获取所有东西来加快速度。

有帮助吗?

解决方案

RFC 3501说Fetch采用了一个序列集,但是我没有看到该序列的定义,该示例使用了范围表格(2:4 =消息2、3和4)。我发现逗号分开的ID列表有效。在与imaplib的python中,我有类似的东西:

    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

其他提示

您可以尝试此操作以获取所有邮件的标题信息,只需访问服务器即可。

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')
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top