欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python如何實現(xiàn)自動發(fā)送郵件

 更新時間:2021年11月22日 11:04:16   作者:俊紅的數(shù)據分析之路  
對于一些每天需要發(fā)的報表或者是需要一次發(fā)送多份的報表,我們可以考慮借助Python來自動發(fā)送郵件。本文主要介紹了如何利用Python實現(xiàn)自動發(fā)送郵件,感興趣的小伙伴可以了解一下

自動發(fā)送郵件

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

使用郵箱的第一步

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

就是除了在輸入賬號密碼以外,還需要輸入一個服務器鏈接地址,這個地址每個公司都會不太一樣。

一份郵件的組成

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

如何發(fā)送郵件

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

不同郵箱的服務器鏈接地址不一樣,大家根據自己使用的郵箱設置相應的服務器鏈接。下表為常見郵箱對應的服務器鏈接:

郵箱 服務器地址
新浪郵箱 smtp.sina.com
搜狐郵箱 smtp.sohu.com
126郵箱 smtp.126.com
139郵箱 smtp.139.com
163網易郵箱 smtp.163.com

在與163郵箱服務器進行連接之前,需要先登陸自己的163郵箱進行授權設置,授權碼設置如下:

點擊設置中的POP3/SMTP/IMAP,勾選SMTP服務,根據提是進行授權碼設置,設置授權成功后,在Python中利用授權碼進行登陸,而不是你本來的郵箱密碼,如果使用本來的郵箱密碼登陸,會報錯。

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

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

import smtplib

smtp = smtplib.SMTP()
smtp.connect(host, port)  # 與服務器進行連接
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="zhangjunhongdata@163.com"
#收件人郵箱
areceiver="zhangjunhong@163.com"
#抄送人郵箱
acc = 'zhangjunhong@qq.com'
#郵件主題
asubject = '這是一份測試郵件'  

#發(fā)件人地址
from_addr = "zhangjunhongdata@163.com"
#郵箱密碼(授權碼)
password="123data"

#郵件設置
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)    

#設置郵箱服務器地址以及端口
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())

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

最后的結果如下圖:

關于自動發(fā)送郵件還有一些進階的內容,比如定時發(fā)送,正文顯示html內容等,大家有興趣的可以自行上網搜索學習。

批量發(fā)送郵件

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

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

根據上述的需要,我們整理了如下收件人信息相關的表格df:

姓名 收件人 抄送人
張俊紅1 zhangjunhong11@163.com zhangjunhong@163.com
張俊紅2 zhangjunhong22@163.com zhangjunhong@163.com

只需要寫一個for循環(huán)去遍歷這個df表格中的信息,然后就可以分別發(fā)送出去,具體實現(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 = "zhangjunhong1227@163.com"
password = "123zjh"

smtp = smtplib.SMTP() #聲明一個鏈接對象
smtp.connect(host, port)  # 與服務器進行連接
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() #聲明一個郵件對象
    msg['from'] = username #發(fā)件人
    msg['to'] = receiver#收件人
    msg['Cc'] = acc #抄送人
    msg['Subject'] = i[0] + "任務明細" #主題

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

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

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

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

以上就是 Python如何實現(xiàn)自動發(fā)送郵件的詳細內容,更多關于 Python發(fā)送郵件的資料請關注腳本之家其它相關文章!

相關文章

  • python+pyqt5實現(xiàn)KFC點餐收銀系統(tǒng)

    python+pyqt5實現(xiàn)KFC點餐收銀系統(tǒng)

    這篇文章主要為大家詳細介紹了python+pyqt5實現(xiàn)KFC點餐收銀系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • 如何用python 操作MongoDB數(shù)據庫

    如何用python 操作MongoDB數(shù)據庫

    這篇文章主要介紹了如何用python 操作MongoDB數(shù)據庫,幫助大家更好的理解和學習使用python,感興趣的朋友可以了解下
    2021-04-04
  • python 匹配url中是否存在IP地址的方法

    python 匹配url中是否存在IP地址的方法

    今天小編就為大家分享一篇python 匹配url中是否存在IP地址的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-06-06
  • python實現(xiàn)蒙特卡羅方法教程

    python實現(xiàn)蒙特卡羅方法教程

    在本篇文章里小編給大家分享了關于python實現(xiàn)蒙特卡羅方法和知識點,有需要的朋友們學習下。
    2019-01-01
  • Python日志處理模塊logging用法解析

    Python日志處理模塊logging用法解析

    這篇文章主要介紹了Python日志處理模塊logging用法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-05-05
  • Python內置函數(shù)delattr的具體用法

    Python內置函數(shù)delattr的具體用法

    本篇文章主要介紹了Python內置函數(shù)delattr的具體用法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • Python Matplotlib庫安裝與基本作圖示例

    Python Matplotlib庫安裝與基本作圖示例

    這篇文章主要介紹了Python Matplotlib庫安裝與基本作圖,簡單分析了Python使用pip命令安裝Matplotlib庫及繪制三角函數(shù)曲線的相關操作技巧,需要的朋友可以參考下
    2019-01-01
  • Python基于回溯法子集樹模板實現(xiàn)8皇后問題

    Python基于回溯法子集樹模板實現(xiàn)8皇后問題

    這篇文章主要介紹了Python基于回溯法子集樹模板實現(xiàn)8皇后問題,簡單說明了8皇后問題的原理并結合實例形式分析了Python回溯法子集樹模板解決8皇后問題的具體實現(xiàn)技巧,需要的朋友可以參考下
    2017-09-09
  • Python實現(xiàn)大樂透號碼隨機生成

    Python實現(xiàn)大樂透號碼隨機生成

    全國有很多彩民,其中購買最多的彩種分別是體彩大樂透和福彩雙色球。本篇文章將介紹Python實現(xiàn)彩票自由的全流程:隨機選取號碼+查看是否中獎,需要的可以參考一下
    2022-05-05
  • 對python dataframe邏輯取值的方法詳解

    對python dataframe邏輯取值的方法詳解

    今天小編就為大家分享一篇對python dataframe邏輯取值的方法詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01

最新評論