溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Python中怎么自動化讀取郵件

發(fā)布時間:2021-07-05 18:09:24 來源:億速云 閱讀:432 作者:Leah 欄目:編程語言

這篇文章將為大家詳細講解有關(guān)Python中怎么自動化讀取郵件,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

一、poplib庫

poplib 模塊提供了 poplib.POP3 和 poplib.POP3_SSL 兩個類,分別用于連接普通的 POP 服務(wù)器和基于  SSL 的 POP 服務(wù)器。連接到服務(wù)器后,按照 POP3 協(xié)議與服務(wù)器交互。

注意:雖然 POP3 得到了廣泛支持,但已過時。POP3 服務(wù)器的實現(xiàn)質(zhì)量差異很大,而且太多的服務(wù)器都很差。后面會介紹基于 IMAP 服務(wù)器的 imbox  庫

下面以 QQ 郵箱為例示范如何完整 poplib 庫的使用

1、創(chuàng)建連接

使用poplib.POP3_SSL創(chuàng)建連接

import poplib import email.parser, email.policy conn = poplib.POP3_SSL('pop.qq.com', 995)

2、登錄服務(wù)器

注意輸入的是郵箱授權(quán)碼而不是真實 QQ 密碼

conn.user('xxxx@qq.com')    conn.pass_('xxxx') # 注意輸入的是郵箱授權(quán)碼而不是真實 QQ 密碼

3、獲取郵件列表

response, maillist, r = conn.list() print('響應(yīng):', response) print('郵件列表:', maillist)

4、遍歷郵件

multipart 代表郵件內(nèi)容的容器,無需處理

msg = email.parser.BytesParser(policy=email.policy.default).parsebytes(data) for part in msg.walk():     # multipart 代表郵件內(nèi)容的容器,無需處理     if part.get_content_type().split("/", 1)[0] == 'multipart':         continue     elif part.get_content_type().split("/", 1)[0] == 'text':         print(part.get_content())     else:             filename = part.get_filename()            print(filename)         with open(filename, 'wb') as f:             f.write(part.get_payload(decode=True))

多級判斷的目的主要是跳過容器、輸出正文、下載附件的本地

5、退出服務(wù)器

conn.quit()

常用的代碼中有部分稍微繁瑣,但整體還是比較好理解的

二 、imbox庫

在正式介紹 imbox 庫之前,再分享一個技巧。從上面 poplib  的代碼中也可以看到,當(dāng)輸入密碼(授權(quán)碼)的時候是在代碼中明文顯示,這就帶來了風(fēng)險:

假如你不小心把這個代碼沒有處理就發(fā)給別人,或者上傳的 github,那么所有拿到這段代碼的人都可以對你的郵箱大肆操作,這是很可怕的事情

這里讀取郵件用的模塊 imbox 也和 poplib 一樣需要密碼這個參數(shù),但不希望在代碼中明文呈現(xiàn)密碼,怎么辦?

”解決辦法是利用 keyring 庫,通過系統(tǒng)密鑰環(huán)將密碼(授權(quán)碼),預(yù)先在本地存儲好,后面在代碼中調(diào)用 keyring  庫的方法,通過賬號把密碼取出來作為變量就可以。

這樣即使別人拿到了全部代碼,但他的本地中沒有預(yù)先配置好密碼,就不會有泄露信息的風(fēng)險了。具體使用方法為,首先打開命令行輸入:

import keyring keyring.set_password("qqmail", "username", "password")

這樣 password 在本地存儲好了,后面只需要 keyring.get_password 獲取作為變量即可:

import keyring password = keyring.get_password('qqmail', 'username')

用 imbox 讀取郵件的代碼如下:

import keyring  from imbox import Imbox password = keyring.get_password('qqmail', 'username')  with Imbox('imap.qq.com', 'xxx@qq.com', password, ssl=True) as imbox:      # 獲取全部郵件     all_inbox_messages = imbox.messages()      for uid, message in all_inbox_messages:          print(message.subject)  # 郵件主題         print(message.body['plain']) # 郵件文本格式正文

Imbox('imap.qq.com', 'xxx@qq.com', password, ssl=True)  這行代碼中需要填寫服務(wù)器、用戶名郵箱、密碼、SSL加密循環(huán)體中 uid  參數(shù)是每封郵件的編號,郵件編號十分重要,可以用于郵件的標記和刪除。除了郵件主題及文本格式正文外,我們主要常用獲取以下內(nèi)容:

Python中怎么自動化讀取郵件

除了獲取全部郵件用 all_inbox_messages = imbox.messages()  外,我們常常會有選擇性獲取已讀、未讀和紅旗標記郵件:

unread_inbox_messages = imbox.messages(unread=True) # 未讀郵件 read_inbox_messages = imbox.messages(unread=False) # 已讀郵件 flagged_inbox_messages = imbox.messages(flagged=True) # 紅旗標記郵件

也可以通過郵件的收件時間獲取郵件:

Python中怎么自動化讀取郵件

inbox_message_before = imbox.messages(date__lt=datetime.date(2021, 1, 18))  inbox_message_after = imbox.messages(date__gt=datetime.date(2021, 1, 18))  inbox_message_on_date = imbox.messages(date__on=datetime.date(2021, 1, 18))

那么如何篩選指定發(fā)件人發(fā)送的郵件呢?答案就在于對 message.sent_from 的理解了。message.sent_from  是一個字典元組,在遍歷的過程中只需要簡單通過 message.sent_from[0]['email']  就能夠?qū)l(fā)件人郵箱提取出來,接著做判斷就能夠達到目的:

with Imbox('imap.qq.com', 'xxx@qq.com', password, ssl=True) as imbox:  all_inbox_messages = imbox.messages()  for uid, message in all_inbox_messages:      print(message.subject)      print(message.sent_from)      print(message.body['plain'])      # 把郵箱提取出來      email = message.sent_from[0]['email']      if email == 某個特定的郵箱:          pass

上文還提到了郵件編號 uid 的重要性。基于編號的兩個重要方法:

  • 標記已讀 imbox.mark_seen(uid)

  • 刪除郵件 imbox.delete(uid)

”使用以刪除郵件為例:

for uid, message in all_inbox_messages:      if 滿足某種條件的郵件:          imbox.delete(uid)

關(guān)于Python中怎么自動化讀取郵件就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI