日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
創(chuàng)新互聯(lián)Python教程:如何使用python收取讀取郵件?

之前給大家介紹使用python去發(fā)送郵件了,那有小伙伴提出疑問(wèn)了,既然能發(fā)送,能否讀取呢?如果可以用python實(shí)現(xiàn),那將是個(gè)非常有趣的事情,于是小編也去查詢了下,下面就給大家演示下,都來(lái)看看吧~以下是具體實(shí)現(xiàn)內(nèi)容,內(nèi)容非常充分,請(qǐng)仔細(xì)閱覽。

專注于為中小企業(yè)提供做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)合肥免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了超過(guò)千家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

關(guān)于讀取郵件:

收取郵件使用POP3協(xié)議;

解析郵件:需要將收取的郵件轉(zhuǎn)化為email.message.Message對(duì)象,再使用email模塊解析內(nèi)容。

讀取郵件的實(shí)例

1、獲取某封郵件的對(duì)象

import poplibfrom email.parser import Parser"""POP的服務(wù)器信息"""popHost = "pop.exmail.qq.com"userAdr = "xx@xx.cn"userPwd = "xxxxx"
""" 創(chuàng)建POP3對(duì)象,添加用戶名和密碼"""pop3Server = poplib.POP3(popHost)pop3Server.user(userAdr)pop3Server.pass_(userPwd)
"""獲取郵件數(shù)量和占用空間"""messageCount, mailboxSize = pop3Server.stat
"""獲取郵件請(qǐng)求返回狀態(tài)碼、每封郵件的字節(jié)大小(b'第幾封郵件 此郵件字節(jié)大小')、"""response, msgNumOctets, octets = pop3Server.list
""" 獲取任意一封郵件的郵件對(duì)象【第一封郵件的編號(hào)為1,而不是0】"""msgIndex = random.randint(1,messageCount)print(msgIndex)# 獲取第msgIndex封郵件的信息response, msgLines, octets = pop3Server.retr(msgIndex)# msgLines中為該郵件的每行數(shù)據(jù),先將內(nèi)容連接成字符串,再轉(zhuǎn)化為email.message.Message對(duì)象msgLinesToStr = b"\r\n".join(msgLines).decode("utf8", "ignore")messageObject = Parser.parsestr(msgLinesToStr)print(messageObject)
""" 終止POP3服務(wù)"""pop3Server.quit

2、解析郵件對(duì)象

3、獲取郵件日期

msgDate = messageObject["date"]print(msgDate)

4、獲取郵件發(fā)件人實(shí)名、郵箱地址

獲取郵件實(shí)名時(shí),名稱一般是加密的,此時(shí)就需要對(duì)頭文件進(jìn)行解碼才可獲取它的實(shí)際內(nèi)容

from email.header import decode_headerdef decodeMsgHeader(header): """ 解碼頭文件 :param header: 需解碼的內(nèi)容 :return: """ value, charset = decode_header(header)[0] if charset: value = value.decode(charset) return value
 
from email.utils import parseaddrsenderContent = messageObject["From"]# parseaddr函數(shù)返回的是一個(gè)元組(realname, emailAddress)senderRealName, senderAdr = parseaddr(senderContent) # 將加密的名稱進(jìn)行解碼 senderRealName = decodeMsgHeader(senderRealName) print(senderRealName)print(senderAdr)

5、獲取郵件主題

獲取的郵件的主題也是加密的,此時(shí)就需要對(duì)頭文件進(jìn)行解碼才可獲取它的實(shí)際內(nèi)容。

msgHeader = messageObject["Subject"]# 對(duì)頭文件進(jìn)行解碼msgHeader = decodeMsgHeader(msgHeader )print(msgHeader)

6、獲取郵件正文

一封郵件的正文內(nèi)容,可能是由幾部分構(gòu)成,每部分的格式不同。

"""獲取郵件正文內(nèi)容"""msgBodyContents = if messageObject.is_multipart: # 判斷郵件是否由多個(gè)部分構(gòu)成 messageParts = messageObject.get_payload # 獲取郵件附載部分 for messagePart in messageParts: bodyContent = decodeBody(messagePart) if bodyContent: msgBodyContents.append(bodyContent)else: bodyContent = decodeBody(messageObject) if bodyContent: messageBodyContents.append(bodyContent)print(msgBodyContents)
 
def decodeBody(msgPart): """ 解碼內(nèi)容 :param msgPart: 郵件某部分 """ contentType = msgPart.get_content_type # 判斷郵件內(nèi)容的類(lèi)型,text/html textContent = "" if contentType == 'text/plain' or contentType == 'text/html': content = msgPart.get_payload(decode=True) charset = msgPart.get_charset if charset is None: contentType = msgPart.get('Content-Type', '').lower position = contentType.find('charset=') if position >= 0: charset = contentType[position + 8:].strip if charset: textContent = content.decode(charset) return textContent

以上就是關(guān)于python郵件獲取內(nèi)容了,如需了解更多python實(shí)用知識(shí),點(diǎn)擊進(jìn)入PyThon學(xué)習(xí)網(wǎng)教學(xué)中心。


名稱欄目:創(chuàng)新互聯(lián)Python教程:如何使用python收取讀取郵件?
網(wǎng)頁(yè)鏈接:http://www.5511xx.com/article/dpoepod.html