python发送邮件带附件_python之简单邮件发送(带附件、图片)

#!/usr/bin/env python

#coding: utf-8 by guozheng_li

#该脚本加入了文本、图片以及附件功能,日常运维跑的脚本基本也就这三样够用了。可以发送给多人,只要添加相应的mailto_list即可,再加入该说明前验证是正常的

import smtplib

from email.mime.multipart import MIMEMultipart

from email.mime.text import MIMEText

from email.mime.p_w_picpath import MIMEImage

mailto_list=['745292907@qq.com','guozheng_li@quantone.com']

mail_host="smtp.163.com" #设置服务器

mail_user="XXX" #用户名

mail_pass="XXXXXX" #口令

mail_postfix="163.com" #发件箱的后缀

def send_mail(to_list,sub):

def addimg(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("""

*官网性能数据 更多>>

""","html","utf-8")

msg.attach(msgtext)

msg.attach(addimg("a.png","io"))

msg.attach(addimg("a.png","key_hit"))

msg.attach(addimg("a.png","men"))

msg.attach(addimg("a.png","swap"))

#添加附件的地方,attach 三条少一不可,缺少最后一条将会发送一串码而不是真正附件。

attach = MIMEText(open("aa.xlsx", "rb").read(), "base64", "utf-8")

attach["Content-Type"] = "application/octet-stream"

attach["Content-Disposition"] = "p_w_upload; filename=\"业务服务质量周报(12周).xlsx\"".decode("utf-8").encode("gb18030")

msg.attach(attach)

me="163"+"<"+mail_user+"@"+mail_postfix+">"

msg['Subject'] = sub

msg['From'] = me

msg['To'] = ";".join(to_list)

try:

server = smtplib.SMTP()

server.connect(mail_host)

server.login(mail_user,mail_pass)

server.sendmail(me, to_list, msg.as_string())

server.close()

return True

except Exception, e:

print str(e)

return False

if __name__ == '__main__':

if send_mail(mailto_list,"hello"):

print "发送成功"

else:

print "发送失败"

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值