0

我有一个 Python 3 脚本,它使用 MIMEMultipart 发送一封电子邮件,其中包含它生成的附加 .xlsx 文件。我曾经在 Py2 上使用相同的脚本来发送相同的生成文件,唯一的区别是 Py2 脚本从 MySQL 收集信息以创建 .xlsx,而 Py3 脚本使用 PostgreSQL 代替。

msg = MIMEMultipart('alternative')
msg.attach(MIMEText("""HTML stuff""", 'html'))

with open(analysis_file, "rb") as fil:
  msg.attach(MIMEApplication(
                    fil.read(),
                    Content_Disposition='attachment; filename="%s"' % os.path.basename(analysis_file),
                    Name=os.path.basename(analysis_file)
                ))

msg['Subject'] = "SUBJECT"
msg['From']="Me <me@me.com>"
msg['To']= "You <you@you.com>"

server.sendmail(FROMADDR, ["you@you.com"], msg.as_string())

然而,当我切换到脚本的 Py3 版本时,附件不再出现在 Microsoft 的 mail.live 上。表示邮件有附件的回形针符号仍然出现,但我找不到。

- 编辑:

如果我设置自动转发到 Gmail 帐户,.xlsx 附件会正常显示在那里;但是,如果我手动转发它,它不会。

4

2 回答 2

7

改变

msg = MIMEMultipart('alternative')

msg = MIMEMultipart('html')

修复。

于 2016-03-14T17:46:56.490 回答
0

帮我一个忙并测试它是否适用于yagmail。对于做 HTML/附件的东西,我认为它真的很有用:默认是用 HTML 发送东西,附件可以通过指向路径来完成。

所有代码:

import yagmail
yag = yagmail.SMTP('me@me.com', 'password')
yag.send("you@you.com", "SUBJECT", analysis_file)

中的第三个字段send是内容,它可以是字符串列表,也可以只是一个字符串。如果字符串可以作为文件加载,它将被简单地附加。

有关更多信息,请查看github页面。请注意,我是开发人员/维护人员。

于 2016-03-10T21:53:59.117 回答