我有一个令我感到困惑的问题。我正在使用imaplib在Sent文件夹中搜索电子邮件,然后将它们导出到csv中。它工作得很好,除了它没有收到所有的电子邮件。它似乎是从当天午夜到下午6点收到电子邮件,然后从下午6点到晚上11:59没有收到任何电子邮件。我相信我读过某个地方,imaplib使用GMT(也许我错了?)所以这可能是问题(我是EST)?除了查询社区之外,我不确定如何解决这个问题。
下面的代码示例。我可以提供任何必要的帮助信息。提前谢谢!
import imaplib
import datetime
import csv
TODAYSDATE = datetime.date.today().strftime("%d-%b-%Y").strip()
ONEDAYAGO = (datetime.date.today() - datetime.timedelta(days=1)).strftime("%d-%b-%Y").strip()
SERVER = 'server.email.com'
IMAPPORT = 993
CSVFILE = "EMAILS.csv"
EMAILS = []
TO = []
mailbox = imaplib.IMAP4_SSL(SERVER, IMAPPORT)
mailbox.login(USER, PASS)
mailbox.select('Sent')
typ, data = mailbox.search(None, '(since %s before %s)' % (ONEDAYAGO, TODAYSDATE))
for sentto in data[0].split():
typ, data = mailbox.fetch(sentto, '(RFC822.SIZE BODY[HEADER.FIELDS (TO)])')
message = data[0][1].lstrip('To: ').strip() + ' '
print message
TO.append([message])
TO.insert(0, ['TO'])
TO_FINAL = [l[0] for l in TO]
mailbox.close()
mailbox.logout()
rows = zip(TO_FINAL)
print rows
CSV = open(CSVFILE, 'wb')
WRITECSV = csv.writer(CSV)
for row in rows:
WRITECSV.writerow(row)
答案 0 :(得分:1)
我想出了我的问题。我没有正确关闭我的CSV文件。嘘我!这有助于我识别和解决我的问题 - > https://stackoverflow.com/questions/15772275/writing-to-csv-from-list-write-row-seems-to-stop-in-a-strange-place