fetch
方法给出了这个错误:
imaplib.IMAP4.error:FETCH命令错误:BAD [b'不能解析命令']
我没有附上我的所有代码。我想获取看不见的消息,使用imap获取正文并将其保存为文本,然后下载附件。
import imaplib, email, os
user= "test9101997"
password="Monday@123"
imap_url="imap.gmail.com"
attach_dir='E:\PROJECT\attachment'
filePath='D:\ATTACH'
con=imaplib.IMAP4_SSL(imap_url)
con.login(user,password)
con.select('INBOX')
#UIDs=con.search(None,'UNSEEN')
#print(UIDs)
(result, messages) = con.search(None, 'UnSeen')
if result == "OK":
for message in messages:
try:
ret, data =con.fetch(message,'(RFC822)')
except:
print ("No new emails to read.")
#self.close_connection()
#exit()
#result, data=con.fetch(i,'(RFC822)')
raw=email.message_from_bytes(data[0][1])
我想你可能会对con.search()
的回报值感到困惑。如果你在调用之后看一下messages
的值(假设result
是OK
),它是字符串的集合,而不是消息id的列表。也就是说,在调用之后:
result, messages = con.search(None, 'UnSeen')
messages
的值可能类似于:
['1 2 15 20']
所以当你试图像这样迭代它:
for message in messages:
第一次循环迭代中的消息值将是1 2 15 20
,这就是你得到命令错误的原因:你正在做的请求没有任何意义。你会想做这样的事情:
(result, blocks) = con.search(None, 'UnSeen')
if result == "OK":
for messages in blocks:
for message in messages.split():
ret, data = con.fetch(message, '(RFC822)')
raw = email.message_from_bytes(data[0][1])
imaplib
模块以这种方式返回数据真的没有充分的理由。