一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術(shù)及教程分享平臺(tái)!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Python - Python如何實(shí)現(xiàn)自動(dòng)發(fā)送郵件

Python如何實(shí)現(xiàn)自動(dòng)發(fā)送郵件

2022-03-05 14:24俊紅的數(shù)據(jù)分析之路 Python

對于一些每天需要發(fā)的報(bào)表或者是需要一次發(fā)送多份的報(bào)表,我們可以考慮借助Python來自動(dòng)發(fā)送郵件。本文主要介紹了如何利用Python實(shí)現(xiàn)自動(dòng)發(fā)送郵件,感興趣的小伙伴可以了解一下

自動(dòng)發(fā)送郵件

我們把報(bào)表做出來以后一般都是需要發(fā)給別人查看,對于一些每天需要發(fā)的報(bào)表或者是需要一次發(fā)送多份的報(bào)表,這個(gè)時(shí)候可以考慮借助Python來自動(dòng)發(fā)送郵件。

使用郵箱的第一步

一般我們在使用QQ郵箱、163郵箱、126郵箱等這些比較常用的郵箱時(shí),只需要輸入賬號(hào)和密碼就可以。但是在使用手機(jī)端的企業(yè)郵箱的時(shí)候,一般都需要配置一下,常規(guī)的配置界面如下所示:

Python如何實(shí)現(xiàn)自動(dòng)發(fā)送郵件

就是除了在輸入賬號(hào)密碼以外,還需要輸入一個(gè)服務(wù)器鏈接地址,這個(gè)地址每個(gè)公司都會(huì)不太一樣。

 

一份郵件的組成

下圖是outlook中發(fā)送一份郵件的界面,主要包含發(fā)件人、收件人、抄送人、主題、正文、附件這幾部分。這也是一般郵件比較通用的組成部分。

Python如何實(shí)現(xiàn)自動(dòng)發(fā)送郵件

如何發(fā)送郵件

在發(fā)送郵件之前首先需要與服務(wù)器進(jìn)行連接,在Python中主要利用smtplib模塊來建立服務(wù)器連接接、服務(wù)器斷開的工作。

不同郵箱的服務(wù)器鏈接地址不一樣,大家根據(jù)自己使用的郵箱設(shè)置相應(yīng)的服務(wù)器鏈接。下表為常見郵箱對應(yīng)的服務(wù)器鏈接:

郵箱 服務(wù)器地址
新浪郵箱 smtp.sina.com
搜狐郵箱 smtp.sohu.com
126郵箱 smtp.126.com
139郵箱 smtp.139.com
163網(wǎng)易郵箱 smtp.163.com

在與163郵箱服務(wù)器進(jìn)行連接之前,需要先登陸自己的163郵箱進(jìn)行授權(quán)設(shè)置,授權(quán)碼設(shè)置如下:

Python如何實(shí)現(xiàn)自動(dòng)發(fā)送郵件

點(diǎn)擊設(shè)置中的POP3/SMTP/IMAP,勾選SMTP服務(wù),根據(jù)提是進(jìn)行授權(quán)碼設(shè)置,設(shè)置授權(quán)成功后,在Python中利用授權(quán)碼進(jìn)行登陸,而不是你本來的郵箱密碼,如果使用本來的郵箱密碼登陸,會(huì)報(bào)錯(cuò)。

連接設(shè)置好以后就可以使用賬戶密碼進(jìn)行登錄了,登錄成功以后就可以對郵件內(nèi)容進(jìn)行編輯,編輯完成以后就可以點(diǎn)擊發(fā)送了,發(fā)送完成后斷開服務(wù)器鏈接。

如下展示了發(fā)送一份郵件的簡短流程代碼:

import smtplib

smtp = smtplib.SMTP()
smtp.connect(host, port)  # 與服務(wù)器進(jìn)行連接
smtp.set_debuglevel(1) #顯示出交互信息
smtp.login(username, password)  # 登陸郵箱
smtp.sendmail(sender, receiver, msg.as_string())  # 發(fā)送郵件
smtp.quit()  # 斷開連接

 

正式發(fā)送一份郵件

如下以163郵箱為例,展示了發(fā)送一份郵件完整的Python代碼:

import smtplib
from email.mime.multipart import MIMEMultipart 
from email import encoders
from email.header import Header
from email.mime.text import MIMEText
from email.utils import parseaddr, formataddr
from email.mime.application import MIMEApplication

#發(fā)件人郵箱
asender="[email protected]"
#收件人郵箱
areceiver="[email protected]"
#抄送人郵箱
acc = '[email protected]'
#郵件主題
asubject = '這是一份測試郵件'  

#發(fā)件人地址
from_addr = "[email protected]"
#郵箱密碼(授權(quán)碼)
password="123data"

#郵件設(shè)置
msg = MIMEMultipart()
msg['Subject'] = asubject  
msg['to'] = areceiver  
msg['Cc'] = acc 
msg['from'] =  "張俊紅"

#郵件正文
body = "你好,這是一份測試郵件"

#添加郵件正文:
msg.attach(MIMEText(body, 'plain', 'utf-8'))

#添加附件
#注意這里的文件路徑是斜杠
xlsxpart = MIMEApplication(open('C:/Users/zhangjunhong/Desktop/這是附件.xlsx', 'rb').read())
xlsxpart.add_header('Content-Disposition', 'attachment', filename='這是附件.xlsx')
msg.attach(xlsxpart)    

#設(shè)置郵箱服務(wù)器地址以及端口
smtp_server ="smtp.163.com"
server = smtplib.SMTP(smtp_server, 25)
server.set_debuglevel(1)

#登陸郵箱
server.login(from_addr, password)

#發(fā)送郵件
server.sendmail(from_addr, areceiver.split(',')+acc.split(','), msg.as_string())

#斷開服務(wù)器鏈接
server.quit()

最后的結(jié)果如下圖:

Python如何實(shí)現(xiàn)自動(dòng)發(fā)送郵件

關(guān)于自動(dòng)發(fā)送郵件還有一些進(jìn)階的內(nèi)容,比如定時(shí)發(fā)送,正文顯示html內(nèi)容等,大家有興趣的可以自行上網(wǎng)搜索學(xué)習(xí)。

 

批量發(fā)送郵件

如果是需要同時(shí)發(fā)送多份郵件,可以把收件人整理成一個(gè)表格進(jìn)行循環(huán)遍歷,挨個(gè)進(jìn)行發(fā)送。

比如我們現(xiàn)在需要給銷售部門好幾百銷售人員分別發(fā)送本月各自的銷售任務(wù),在發(fā)送郵件的時(shí)候主題需要命名成xxx任務(wù)明細(xì),在正文中的稱呼也需要改成對應(yīng)的收件人,附件中需要添加各自的任務(wù)明細(xì)表,而且需要抄送給各自的直屬上級(jí)。

根據(jù)上述的需要,我們整理了如下收件人信息相關(guān)的表格df:

姓名 收件人 抄送人
張俊紅1 [email protected] [email protected]
張俊紅2 [email protected] [email protected]

只需要寫一個(gè)for循環(huán)去遍歷這個(gè)df表格中的信息,然后就可以分別發(fā)送出去,具體實(shí)現(xiàn)代碼如下:

import smtplib
from email.mime.multipart import MIMEMultipart 
from email.mime.text import MIMEText
from email.mime.image import MIMEImage
from email.mime.application import MIMEApplication

host = "smtp.163.com"
port = 25
username = "[email protected]"
password = "123zjh"

smtp = smtplib.SMTP() #聲明一個(gè)鏈接對象
smtp.connect(host, port)  # 與服務(wù)器進(jìn)行連接
smtp.set_debuglevel(1) #顯示出交互信息
smtp.login(username, password)  # 登陸郵箱

sender = username

for i in zip(df["姓名"],df["收件人"],df["抄送人"]):
  
  receiver = i[1] #收件人
  acc = i[2] #抄送人


  msg = MIMEMultipart() #聲明一個(gè)郵件對象
  msg['from'] = username #發(fā)件人
  msg['to'] = receiver#收件人
  msg['Cc'] = acc #抄送人
  msg['Subject'] = i[0] + "任務(wù)明細(xì)" #主題

  # 編寫正文
  text = MIMEText(i[0]+"您好,這是您這個(gè)月的任務(wù)明細(xì)",'plain', 'utf-8') 
  msg.attach(text)

  # 添加表格附件
  f = open('C:/Users/zhangjunhong/Desktop/任務(wù)明細(xì)/'+ i[0] + '.xlsx', 'rb').read()
  filepart = MIMEApplication(f)
  filepart.add_header('Content-Disposition','attachment',filename=i[0] + '任務(wù)明細(xì).xlsx') #為附件添加一個(gè)標(biāo)題
  msg.attach(filepart)

  smtp.sendmail(sender, receiver.split(',') + acc.split(','), msg.as_string())  # 發(fā)送郵件
smtp.quit()  # 斷開連接    

通過運(yùn)行上面的代碼,就可以達(dá)到一次性給表格df中的所有人發(fā)送郵件的需求。

以上就是 Python如何實(shí)現(xiàn)自動(dòng)發(fā)送郵件的詳細(xì)內(nèi)容,更多關(guān)于 Python發(fā)送郵件的資料請關(guān)注服務(wù)器之家其它相關(guān)文章!

原文鏈接:https://blog.csdn.net/junhongzhang/article/details/121436971

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲欧美日韩成人一区在线 | 99国产小视频 | 国产精品美女久久久久网站 | 92国产福利久久青青草原 | 9966久久精品免费看国产 | 亚洲欧洲日产国码天堂 | 免费91麻豆精品国产自产在线观看 | 成人黄色免费网站 | 久久免费国产 | 2022天天干| 蜜桃麻豆| 欧美一区二区三区gg高清影视 | 国产伦精一区二区三区视频 | 第一福利在线视频 | 高清女主播一区二区三区 | 扒开老女人 | 日本videosdesexo乱 | 亚洲欧美另类在线观看 | sex5·性屋娱乐| 欧美在线欧美 | 亚洲老头老太hd | 亚洲国产欧美在线人成 | 男人狂躁女人下面狂叫图片 | 欧美精品一区二区在线观看 | 九九99香蕉在线视频免费 | 天天操天天爽天天射 | 精品久久久久久 | 日本黄色高清视频网站 | 男人的j进入女人的j免费 | 成人综合久久综合 | 猛吸奶水的老汉 | 四川女人偷人真实视频 | 国产一卡| 男生操女生的漫画 | 欧美大片一区二区 | 欧美视频免费 | 美国一级大黄大色毛片 | 天天av天天翘天天综合网 | 国产 国语对白 露脸正在播放 | 护士被多人调教到失禁h | 国产成人精品在线观看 |