python邮件发送带附件

本文介绍如何使用Python的smtplib模块及email.mime.*模块发送包含HTML格式正文、内嵌图片和附件的电子邮件。通过具体代码示例展示了邮件内容的构造过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

smtplib模块负责连接服务器和发送邮件
MIMEImage类:定义邮件的图片数据
MIMEText:HTML格式的邮件,定义Content-Disposition属性可以实现带附件
MIMEMultipart:负责将文字图片音频组装在一起和添加附件

#coding:utf-8
#!/usr/bin python 

from email.mime.multipart import  MIMEMultipart
from email.mime.text  import MIMEText
from email.mime.image import MIMEImage
import smtplib
HOST = "smtp.qq.com"
SUBJECT = "官网业务服务质量周报"
TO = "收件人"
FROM = "发件人"

def adding(src ,imgid):
    fp = open(src,'rb')
    msgImage = MIMEImage(fp.read())
    fp.close()
    msgImage.add_header("Content-ID",imgid)
    return msgImage

msg = MIMEMultipart("related")
msgtext = MIMEText("<font color=red>官网业务周平均延时图表:<br><img src=\"cid:weekly\"border=\"1\"><br>详细见附件.</font>","html","utf-8")
msg.attach(msgtext)
msg.attach(adding("img/2.jpg","weekly"))

attach = MIMEText(open("doc/week.xlsx","rb").read(),"base64","utf-8")
attach["Content-Type"] = "application/octet-stream"
attach["Content-Disposition"] = "attachment;filename=\"业务服务质量周报.xlsx\"".decode("utf-8").encode("gb18030")

msg.attach(attach)
msg['Subject'] = SUBJECT
msg['From'] = FROM
msg['To'] = TO
try:
    server = smtplib.SMTP()
    server.connect(HOST,"25")
    server.starttls()
    server.login("账号","密码")
    server.sendmail(FROM,TO,msg.as_string())
    server.quit()
    print "ok"
except Exception,e:
    print "fail"+str(e)

注意事项:
1.#!/usr/bin/env python 会出现编码错误
2 Content-ID ,filename 名词不能打错
3 在程序保存的位置下,分别建立doc文件,img文件

( 写于2016年3月16日,http://blog.youkuaiyun.com/bzd_111

为了实现通过Python发送Excel附件邮件,可以组合使用`email`库来构建邮件结构以及`smtplib`来进行邮件传输。下面是一个具体的例子: ```python import smtplib from email.mime.multipart import MIMEMultipart from email.mime.text import MIMEText from email.mime.base import MIMEBase from email import encoders def send_email_with_excel_attachment(sender_address, sender_pass, receiver_address, subject, body, excel_path): message = MIMEMultipart() message['From'] = sender_address message['To'] = receiver_address message['Subject'] = subject # 添加邮件正文 message.attach(MIMEText(body, 'plain')) # 打开文件并设置为MIME应用/八位字节流对象 with open(excel_path, "rb") as attachment: part = MIMEBase('application', 'octet-stream') part.set_payload(attachment.read()) encoders.encode_base64(part) part.add_header( 'Content-Disposition', f'attachment; filename= {excel_path}', ) message.attach(part) session = smtplib.SMTP('smtp.gmail.com', 587) # 使用Gmail作为SMTP服务器为例 session.starttls() # 启用TLS加密 session.login(sender_address, sender_pass) # 登录件箱 text = message.as_string() session.sendmail(sender_address, receiver_address, text) session.quit() send_email_with_excel_attachment("your_email@gmail.com", "password", "receiver@example.com", "Test Subject", "This is test mail.", "/path/to/excel/file.xlsx") ``` 此代码片段展示了创建一个多部分消息体,其中一部分是纯文本形式的邮件主体,另一部分则是以二进制方式读取的Excel文件,并将其编码成base64格式附加到邮件中[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值