【发布时间】:2017-08-30 02:14:56
【问题描述】:
我正在尝试附加一个 CSV 文件并通过电子邮件发送。
目前,我正在执行以下操作,但它只是附加一个空的 CSV 文件,而不是附加我在同一目录中的 CSV 文件:
import smtplib
from email.mime.multipart import MIMEMultipart
from email.mime.base import MIMEBase
from email.mime.text import MIMEText
from email.utils import COMMASPACE
from email import encoders
def email_attachment():
SUBJECT = 'Subject string'
msg = MIMEMultipart()
msg['From'] = 'my_email@yahoo.com'
msg['To'] = COMMASPACE.join(['recepient_email@gmail.com'])
msg['Subject'] = SUBJECT
part = MIMEBase('application', "octet-stream")
# I have a CSV file named `attachthisfile.csv` in the same directory that I'd like to attach and email
part.set_payload(open("./attachthisfile.csv", "rb").read())
encoders.encode_base64(part)
part.add_header('Content-Disposition', 'attachment', filename='attachthisfile.csv')
msg.attach(part)
smtpObj = smtplib.SMTP('smtp.mail.yahoo.com', 587)
smtpObj.ehlo()
smtpObj.starttls()
smtpObj.login('my_email@yahoo.com', 'myemailpassword')
smtpObj.sendmail('my_email@yahoo.com', 'recepient_email@gmail.com', msg.as_string())
smtpObj.quit()
所以我的问题是,我做错了什么?如何将 CSV 文件附加到同一目录和电子邮件中,而不是创建一个空的 CSV 文件并将其命名为相同,然后通过电子邮件发送?
【问题讨论】:
-
请参阅revisions 了解其他一些字符修复。
标签: python csv email smtp mime