将数据框作为excel文件附加到由python触发的电子邮件中

将数据框作为excel文件附加到由python触发的电子邮件中,python,pandas,email,Python,Pandas,Email,我有一个pandas数据框架,它基本上是sql查询的集合。 我想在一封由python触发的自动电子邮件中附加为xlsx,该excel文件应该包含提到的数据框架。如何做到这一点 我能够成功发送没有附件的电子邮件,但没有附件 import pandas as pd data= pd.DataFrame(output of sqlquery) # this data is dataframe output of a sql query. # import necessary packages f

我有一个pandas数据框架,它基本上是sql查询的集合。 我想在一封由python触发的自动电子邮件中附加为xlsx,该excel文件应该包含提到的数据框架。如何做到这一点

我能够成功发送没有附件的电子邮件,但没有附件

import pandas as pd

data= pd.DataFrame(output of sqlquery) # this data is dataframe output of a sql query. 

# 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文件。
首先,必须将该数据框写入excel,然后附加该数据框

对于将dataframe写入excel-data.to_excel('data.xlsx'),这非常好。因此,由于使用了excel函数,每次运行脚本时都会下载该文件。如果我想附加它而不将其保存到系统中,该怎么办?还有其他方法吗?@Rajat Arora很高兴它帮助了你,如果它起作用,你能接受这个答案吗?为了结束这个问题,谢谢通过链接了解如何接受答案。你能接受这个问题的答案吗?@Rajat Arora
import smtplib
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.mime.base import MIMEBase
from email import encoders

fromaddr = '@gmail.com'
toaddr = ['@gmail.com', '@gmail.com', 
'@gmail.com']

msg = MIMEMultipart()

msg['From'] = fromaddr
msg['To'] = ", ".join(toaddr)
msg['Subject'] = "Hello"

body = "Sample Mail"

msg.attach(MIMEText(body, 'plain'))

filename = "Data.xlsx"
attachment = open("C:\\Users\\Desktop\\file.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)

server = smtplib.SMTP('smtp.gmail.com', 587)
server.starttls()
server.login(fromaddr, "TYPEPASSWORD") #Type Password
text = msg.as_string()
server.sendmail(fromaddr, toaddr, text)
server.quit()