邮件发送携带附件

#!/usr/bin/env python
#-*- coding:utf-8 -*-
from email import encoders
from email.header import Header
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.mime.base import MIMEBase
from email.utils import parseaddr, formataddr

import smtplib

def _format_addr(s):
    name, addr = parseaddr(s)
    return formataddr((Header(name, 'utf-8').encode(), addr))

#from_addr = input('From: ')
#password = input('Password: ')
#to_addr = input('To: ')
#smtp_server = input('SMTP server: ')
from_addr='jusda-it-infra@mail.jusdascm.com'
password='JusdaG1702543'
to_addr='1766070823@qq.com'
smtp_server='smtp.mxhichina.com'

# 邮件对象:
msg = MIMEMultipart()
msg['From'] = _format_addr('告警服务器<%s>' % from_addr)
msg['To'] = _format_addr('Evmi 服务器运维人员<%s>' % to_addr)
msg['Subject'] = Header('Evmi JOBs 告警表格汇总', 'utf-8').encode()

# 邮件正文是MIMEText:
msg.attach(MIMEText('EVMI服务器10.134.167.126计划任务异常告警发送', 'plain', 'utf-8'))

# 添加附件就是加上一个MIMEBase,从本地读取一个图片:
with open('''F:\\data.xls''', 'rb') as f:
    # 设置附件的MIME和文件名,这里是png类型:
    mime = MIMEBase('image', 'png', filename='11.xlsx')
    # 加上必要的头信息:
    mime.add_header('Content-Disposition', 'attachment', filename='a11.xlsx')
    mime.add_header('Content-ID', '<0>')
    mime.add_header('X-Attachment-Id', '0')
    # 把附件的内容读进来:

    mime.set_payload(f.read())
    # 用Base64编码:
    encoders.encode_base64(mime)
    # 添加到MIMEMultipart:
    msg.attach(mime)

server = smtplib.SMTP(smtp_server, 25)
server.set_debuglevel(1)
server.login(from_addr, password)
server.sendmail(from_addr, [to_addr], msg.as_string())
server.quit()

转载于:https://www.cnblogs.com/NGU-PX/p/11322620.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值