如何在从 python 触发的电子邮件中将 pandas 数据框附加为 excel
Posted
技术标签:
【中文标题】如何在从 python 触发的电子邮件中将 pandas 数据框附加为 excel【英文标题】:How attach pandas dataframe as excel in email triggered from python 【发布时间】:2019-09-10 05:36:50 【问题描述】:我有一个 pandas 数据框,我想将它作为 xls 附加到从 python 触发的自动电子邮件中。这是怎么做到的
我可以成功发送不带附件但不带附件的电子邮件。
我的代码
import os
import pandas as pd
#read and prepare dataframe
data= pd.read_csv("C:/Users/Bike.csv")
data['Error'] = data['Act'] - data['Pred']
df = data.to_excel("Outpout.xls")
# import necessary packages
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
import smtplib
# create message object instance
msg = MIMEMultipart()
password = "password"
msg['From'] = "xyz@gmail.com"
msg['To'] = "abc@gmail.com"
msg['Subject'] = "Messgae"
server = smtplib.SMTP('smtp.gmail.com:587')
server.starttls()
# Login Credentials for sending the mail
server.login(msg['From'], password)
server.sendmail(msg['From'], msg['To'], msg.as_string())
【问题讨论】:
您似乎没有将 excel 文件附加到电子邮件中。如果你不这样做,它就没有机会被发送。 【参考方案1】:正如评论中指出的,您没有附加文件,因此不会发送。
msg.attach(MIMEText(body, 'plain'))
filename = "Your file name.xlsx"
attachment = open("/path/to/file/Your file name.xlsx","rb")
part = MIMEBase('application', 'octet-stream')
part.set_payload((attachment).read())
encoders.encode_base64(part)
part.add_header('Content-Disposition',"attachment; filename=%s" % filename)
msg.attach(part)
text = msg.as_string()
smtp0bj.sendmail(msg['From'], msg['To'], text)
希望对你有帮助
【讨论】:
我是否应该像附加之前一样将数据框保存为 excel。 我不确定是否有办法不按原样保存和发送。以上是关于如何在从 python 触发的电子邮件中将 pandas 数据框附加为 excel的主要内容,如果未能解决你的问题,请参考以下文章
如何使用exchangelib在python中将熊猫数据框作为电子邮件附件发送
如何使用python从熊猫数据框中将电子邮件发送到具有不同主题的不同收件人地址