Python实现各种邮件发送

目录
  • 一、发送纯文本内容
  • 二、发送附件图片
  • 三、发送纯文本附件
  • 四、发送excel表格附件

前言:

Python内置对SMTP的支持,可以发送纯文本邮件、HTML邮件以及带附件的邮件。

Python对SMTP支持有smtplib和email两个模块,email负责构造邮件,smtplib负责发送邮件。

一、发送纯文本内容

代码如下:

# 引入相应的模块
import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.mime.multipart import MIMEBase
from email import encoders
from email.utils import parseaddr, formataddr
class SendMail(object):
   def __init__(self):
       self.fromUser = "xxxxxx@qq.com"
       self.userPasswd = "xxxxxx"      # 此处是qq邮箱授权码, 不是登录密码
       self.smtpAddr = "smtp.qq.com"
   # 构造邮件结构
   # toAddrs 收件人可以是多个,["xxx@qq.com","xxx@qq.com"], subject 邮件的主题, msg 邮件的内容
   def mailStructure(self, toAddrs, subject, msg):
       # 邮件对象:
       mailMsg = MIMEMultipart()
       mailMsg['Subject'] = ("Hello <%s>" % subject)
       mailMsg['From'] = ("Python管理员 <%s>" % self.fromUser)
       mailMsg['To'] = ','.join(toAddrs)
       # 邮件正文是MIMEText :
       mailMsg.attach(MIMEText(msg, 'html', 'utf-8'))
       return mailMsg.as_string()

   # 发送邮件
   def sendMail(self, toAddrs, subject, msg):
       mailMsg_as_string = self.mailStructure(toAddrs, subject, msg)
       # 连接服务器发送邮件
       try:
           server = smtplib.SMTP_SSL(self.smtpAddr, 465)
           server.connect(self.smtpAddr)  # 连接smtp服务器
           server.login(self.fromUser, self.userPasswd)  # 登录邮箱
           server.sendmail(self.fromUser, toAddrs, mailMsg_as_string)  # 发送邮件
           server.quit()
       except Exception:
           print("Error: unable to send email")
a = SendMail()
a.sendMail(["381347268@qq.com", "44934875@qq.com"], "测试主题", "测试内容")

效果图:

二、发送附件图片

代码如下:

如果Email中要加上附件怎么办?带附件的邮件可以看做包含若干部分的邮件:文本和各个附件本身,所以,可以构造一个MIMEMultipart对象代表邮件本身,然后往里面加上一个MIMEText作为邮件正文,再继续往里面加上表示附件的MIMEBase对象即可:

其实就是打开图片并引入(加上这段内容)

with open(r"C:\Users\YJ\Desktop\favicon.png", "rb") as f:
# 设置附件的MIME和文件名,这里是png类型:
mime = MIMEBase("image", "png", filename="test.png")
# 加上必要的头信息:
mime.add_header('Content-Disposition', 'attachment', filename='test.png')
mime.add_header('Content-ID', '<0>')
mime.add_header('X-Attachment-Id', '0')
# 把附件的内容读进来:
mime.set_payload(f.read())
# 用Base64编码:
encoders.encode_base64(mime)
# 添加到MIMEMultipart:
mailMsg.attach(mime)

发送附件图片 (完整代码如下:)

# 引入相应的模块
import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.mime.multipart import MIMEBase
from email import encoders
from email.utils import parseaddr, formataddr
class SendMail(object):
def __init__(self):
self.fromUser = "xxxxxx@qq.com"
self.userPasswd = "xxxxxx" # 此处是qq邮箱授权码, 不是登录密码
self.smtpAddr = "smtp.qq.com"

# 构造邮件结构
# toAddrs 收件人可以是多个,["xxx@qq.com","xxx@qq.com"], subject 邮件的主题, msg 邮件的内容
def mailStructure(self, toAddrs, subject, msg):
# 邮件对象:
mailMsg = MIMEMultipart()
mailMsg['Subject'] = ("Hello <%s>" % subject)
mailMsg['From'] = ("Python管理员 <%s>" % self.fromUser)
mailMsg['To'] = ','.join(toAddrs)
# 邮件正文是MIMEText :
mailMsg.attach(MIMEText(msg, 'html', 'utf-8'))

# 发送图片附件, 需要用到附件对象MIMEBase对象, 需要引入from email.mime.multipart import MIMEBase
# 添加附件就是加上一个MIMEBase,从本地读取一个图片:
with open(r"C:\Users\YJ\Desktop\favicon.png", "rb") as f:
# 设置附件的MIME和文件名,这里是png类型:
mime = MIMEBase("image", "png", filename="test.png")
# 加上必要的头信息:
mime.add_header('Content-Disposition', 'attachment', filename='test.png')
mime.add_header('Content-ID', '<0>')
mime.add_header('X-Attachment-Id', '0')
# 把附件的内容读进来:
mime.set_payload(f.read())
# 用Base64编码:
encoders.encode_base64(mime)
# 添加到MIMEMultipart:
mailMsg.attach(mime)
return mailMsg.as_string()
# 发送邮件
def sendMail(self, toAddrs, subject, msg):
mailMsg_as_string = self.mailStructure(toAddrs, subject, msg)
# 连接服务器发送邮件
try:
server = smtplib.SMTP_SSL(self.smtpAddr, 465)
server.connect(self.smtpAddr) # 连接smtp服务器
server.login(self.fromUser, self.userPasswd) # 登录邮箱
server.sendmail(self.fromUser, toAddrs, mailMsg_as_string) # 发送邮件
server.quit()
except Exception:
print("Error: unable to send email")
a = SendMail()
a.sendMail(["381347268@qq.com", "44934875@qq.com"], "测试主题", "测试内容")

效果图:

如果要把一个图片嵌入到邮件正文中怎么做?直接在HTML邮件中链接图片地址行不行?答案是,大部分邮件服务商都会自动屏蔽带有外链的图片,因为不知道这些链接是否指向恶意网站。

要把图片嵌入到邮件正文中,我们只需按照发送附件的方式,先把邮件作为附件添加进去,然后,在HTML中通过引用src="cid:0"就可以把附件作为图片嵌入了。如果有多个图片,给它们依次编号,然后引用不同的cid:x即可。

其实就是将MIMEText 格式改变一下:

mailMsg.attach(MIMEText('<html><body><h1>%s</h1>' % (msg) + '<p><img src="cid:0"></p>' + '</body></html>', 'html','utf-8'))

将附件图片包含在邮件内容中(完整代码如下:)

# 引入相应的模块
import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.mime.multipart import MIMEBase
from email import encoders
from email.utils import parseaddr, formataddr
class SendMail(object):
def __init__(self):
self.fromUser = "xxxxxx@qq.com"
self.userPasswd = "xxxxxx" # 此处是qq邮箱授权码, 不是登录密码
self.smtpAddr = "smtp.qq.com"

# 构造邮件结构
# toAddrs 收件人可以是多个,["xxx@qq.com","xxx@qq.com"], subject 邮件的主题, msg 邮件的内容
def mailStructure(self, toAddrs, subject, msg):
# 邮件对象:
mailMsg = MIMEMultipart()
mailMsg['Subject'] = ("Hello <%s>" % subject)
mailMsg['From'] = ("Python管理员 <%s>" % self.fromUser)
mailMsg['To'] = ','.join(toAddrs)
# 邮件正文是MIMEText :
# 加载图片并引入到邮件内容中来
mailMsg.attach(MIMEText('<html><body><h1>%s</h1>' % (msg) + '<p><img src="cid:0"></p>' + '</body></html>', 'html','utf-8'))
# 发送图片附件, 需要用到附件对象MIMEBase对象, 需要引入from email.mime.multipart import MIMEBase
# 添加附件就是加上一个MIMEBase,从本地读取一个图片:
with open(r"C:\Users\YJ\Desktop\favicon.png", "rb") as f:
# 设置附件的MIME和文件名,这里是png类型:
mime = MIMEBase("image", "png", filename="test.png")
# 加上必要的头信息:
mime.add_header('Content-Disposition', 'attachment', filename='test.png')
mime.add_header('Content-ID', '<0>')
mime.add_header('X-Attachment-Id', '0')
# 把附件的内容读进来:
mime.set_payload(f.read())
# 用Base64编码:
encoders.encode_base64(mime)
# 添加到MIMEMultipart:
mailMsg.attach(mime)
return mailMsg.as_string()

# 发送邮件
def sendMail(self, toAddrs, subject, msg):
mailMsg_as_string = self.mailStructure(toAddrs, subject, msg)
# 连接服务器发送邮件
try:
server = smtplib.SMTP_SSL(self.smtpAddr, 465)
server.connect(self.smtpAddr) # 连接smtp服务器
server.login(self.fromUser, self.userPasswd) # 登录邮箱
server.sendmail(self.fromUser, toAddrs, mailMsg_as_string) # 发送邮件
server.quit()
except Exception:
print("Error: unable to send email")
a = SendMail()
a.sendMail(["381347268@qq.com", "44934875@qq.com"], "测试主题", "测试内容")

效果图:

三、发送纯文本附件

代码如下:

# 引入相应的模块
import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.mime.multipart import MIMEBase
from email import encoders
from email.utils import parseaddr, formataddr
class SendMail(object):
def __init__(self):
self.fromUser = "xxxxxx@qq.com"
self.userPasswd = "xxxxxx" # 此处是qq邮箱授权码, 不是登录密码
self.smtpAddr = "smtp.qq.com"
# 构造邮件结构
# toAddrs 收件人可以是多个,["xxx@qq.com","xxx@qq.com"], subject 邮件的主题, msg 邮件的内容
def mailStructure(self, toAddrs, subject, msg):
# 邮件对象:
mailMsg = MIMEMultipart()
mailMsg['Subject'] = ("Hello <%s>" % subject)
mailMsg['From'] = ("Python管理员 <%s>" % self.fromUser)
mailMsg['To'] = ','.join(toAddrs)
# 邮件正文是MIMEText :
mailMsg.attach(MIMEText(msg, 'html', 'utf-8'))
# 发送文件附件, 需要用到附件对象MIMEBase对象, 需要引入from email.mime.multipart import MIMEBase
# 添加附件就是加上一个MIMEBase,从本地读取一个文件:
with open(r"C:\Users\YJ\Desktop\aaa.txt", "rb") as f:
# 设置附件的MIME和文件名,这里是png类型:
mime = MIMEBase("txta", "txt", filename="test.txt")
# 加上必要的头信息:
mime.add_header('Content-Disposition', 'attachment', filename='test.txt')
mime.add_header('Content-ID', '<0>')
mime.add_header('X-Attachment-Id', '0')
# 把附件的内容读进来:
mime.set_payload(f.read())
# 用Base64编码:
encoders.encode_base64(mime)
# 添加到MIMEMultipart:
mailMsg.attach(mime)
return mailMsg.as_string()
# 发送邮件
def sendMail(self, toAddrs, subject, msg):
mailMsg_as_string = self.mailStructure(toAddrs, subject, msg)
# 连接服务器发送邮件
try:
server = smtplib.SMTP_SSL(self.smtpAddr, 465)
server.connect(self.smtpAddr) # 连接smtp服务器
server.login(self.fromUser, self.userPasswd) # 登录邮箱
server.sendmail(self.fromUser, toAddrs, mailMsg_as_string) # 发送邮件
server.quit()
except Exception:
print("Error: unable to send email")
a = SendMail()
a.sendMail(["381347268@qq.com", "44934875@qq.com"], "测试主题", "测试内容")

效果图:

四、发送excel表格附件

代码如下:

#! /usr/bin/env python
# _*_ coding: utf-8 _*_
import smtplib, time
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
class EmailSender(object):
def __init__(self):
self.sender_user = 'ryb.monitor@yottacloud.cn' #发件人邮箱地址
self.sender_password = 'xxxxxxxxxx' #发件人邮箱密码
self.smtp_server_addr = 'smtp.exmail.qq.com' #smtp服务器地址
self.smtp_server_port = 465 #smtp服务器端口
def main_email(self, text, xlsx_path, xlsx_name):
'''
邮件主题,包含邮件正文 + excel 附件
Args:
text:邮件正文内容
xlsx_path: excel文件路径
xlsx_name: excel文件,例如a.xlsx
Returns: 返回要发送的数据,正文和附件
'''
msg =MIMEMultipart()
#添加纯文本,邮件文本内容,字符串格式
text_msg = MIMEText(text, 'html', 'utf-8')
msg.attach(text_msg)
#将xlsx文件作为内容发送到对方的邮箱读取excel,rb形式读取,对于MIMEText()来说默认的编码形式是base64 对于二进制文件来说没有设置base64,会出现乱码
excel_msg = MIMEText(open(xlsx_path, 'rb').read(), 'base64', 'utf-8')
#设置文件再附件当中的名字
excel_msg.add_header('Content-Disposition', 'attachment', filename=('gbk', '', xlsx_name))
#添加到邮件内容msg中
msg.attach(excel_msg)
return msg
def login_email(self):
server = smtplib.SMTP_SSL(self.smtp_server_addr, self.smtp_server_port) #连接smtp服务器
server.connect(self.smtp_server_addr) #连接smtp服务器
result = server.login(self.sender_user, self.sender_password) #登陆邮箱
print("登陆结果: ", result)
return server
def send_email(self, title, to_receiver, msg):
'''
发送邮件
Args:
title: 邮件的主题
to_receiver: 收件人邮箱地址,可以是列表
msg: main_email函数返回的邮件主体
Returns:
'''
server = self.login_email()
msg['Subject'] = title
msg['From'] = self.sender_user
msg['To'] = ','.join(to_receiver)
msg['Accept-Language']='zh-CN'
msg['Accept-Charset']='ISO-8859-1,utf-8'
server.sendmail(self.sender_user, to_receiver, msg.as_string()) #发送邮件
sed_mail = EmailSender()
text = time.strftime('%Y-%m-%d') + "数据统计"
msg = sed_mail.main_email(text, r'小程序日报V2.0(试行版).xlsx', '小程序日报.xlsx')
sed_mail.send_email(title='数据统计', to_receiver=['yanjie.li@yottacloud.cn', '381347268@qq.com'], msg=ms

到此这篇关于Python实现各种邮件发送的文章就介绍到这了,更多相关Python 发送邮件内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Python如何实现自动发送邮件

    目录 自动发送邮件 使用邮箱的第一步 一份邮件的组成 正式发送一份邮件 批量发送邮件 自动发送邮件 我们把报表做出来以后一般都是需要发给别人查看,对于一些每天需要发的报表或者是需要一次发送多份的报表,这个时候可以考虑借助Python来自动发送邮件. 使用邮箱的第一步 一般我们在使用QQ邮箱.163邮箱.126邮箱等这些比较常用的邮箱时,只需要输入账号和密码就可以.但是在使用手机端的企业邮箱的时候,一般都需要配置一下,常规的配置界面如下所示: 就是除了在输入账号密码以外,还需要输入一个服务器链接地

  • 如何用python批量发送工资条邮件

    目录 思路: 总结反思: 工资excel表格格式如下所示: 使用python批量给每位员工发送工资条信息,格式如下: 思路: 首先是加载excel,获取当前sheet表格 salay = load_workbook('大唐建设集团-2022年5月工资.xlsx', data_only=True) ws = salay.active 登录所使用的发件邮箱服务器 # 登录邮箱服务器 smtp_obj = smtplib.SMTP_SSL('smtp.qq.com', 465) # smtp_obj.

  • Python 统计Jira的bug 并发送邮件功能

    1.首先在pycharm上使用pip安装 pip install html-table pip install jira 2.初始化发件人邮箱,账号,密码 # 发件人邮箱账号 my_sender = 'username@xxx.com.cn' # user登录邮箱的用户名,password登录邮箱的密码(授权码,即客户端密码,非网页版登录密码),但用腾讯邮箱的登录密码也能登录成功 my_pass = 'xxxxx' # 收件人邮箱账号 my_users=['username@xxx.com.cn

  • 用Python定时发送天气邮件

    效果如图 一.获取天气 def getWeather1(city): try: appid = os.environ["TIANQI_APPID"] appsecret = os.environ["TIANQI_APPSEC"] except KeyError: appid = 'x'x'x'x' #www.tianqiapi.com申请的appid,有免费 api appsecret = 'xxxx' #在www.tiaSnqiapi.com申请的appsecre

  • Python实现定时发送监控邮件

    目录 一.自动定时任务运行详情 二.开启POP3/SMTP服务 三.发送邮件 1 导入库 2 设置邮件内容 3 添加附件 4 发送邮件 5 邮件发送效果 四.设置定时任务 1 设置定时任务的具体步骤 2 设置定时任务的教学视频 不管是在信贷领域还是支付领域,作为一个风控人员,我们都需要对部署的策略模型进行监控,信贷领域可能还需要对客户的逾期表现进行监控.这时,如果我们能用python自动连接数据库,对策略.模型.贷后表现等数据进行分析处理,输出标准表格或图片到固定文件夹中.再用python自动定

  • Python实现自动化发送邮件

    目录 开门见山 自动化发送邮件SMTP 介绍 开启SMTP服务 邮件的属性配置 发送文本邮件 发送HTML邮件 发送附件邮件 后记 总结 开门见山 自动化测试过程中,一般测试结果都会以邮件的形式发送给相关人员,那么,在Python中,如何编写代码将邮件发送给对应的用户? 同时,发送邮件时又有不同的形式,比如:文本.HTML.图片附件.非图片附件等,这些又是如何操作的呢?下面我们一起来学习学习~ 自动化发送邮件SMTP 介绍 SMTP中文名为简单邮件传输协议,是一种提供可靠且有效的电子邮件传输的协

  • Python实现自动化邮件发送过程详解

    使用Python实现自动化邮件发送,可以让你摆脱繁琐的重复性业务,可以节省非常多的时间. 操作前配置(以较为复杂的QQ邮箱举例,其他邮箱操作类似) 单击设置-账号,滑倒下方协议处,开启IMAP/SMTP协议(IMAP,即Internet Message Access Protocol(互联网邮件访问协议),可以通过这种协议从邮件服务器上获取邮件的信息.下载邮件等.IMAP与POP类似,都是一种邮件获取协议.) (ps.开启需要验证) 记住端口号,后续写代码发送邮件时候需要 生成授权码,前期配置完

  • Python实现SMTP邮件发送

    SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式. python的smtplib提供了一种很方便的途径发送电子邮件.它对smtp协议进行了简单的封装. SMTP 对象语法如下: import smtplib smtpObj = smtplib.SMTP( [host [, port [, local_hostname]]] ) 参数说明: host: SMTP 服务器主机. 你可以指定

  • Python实现各种邮件发送

    目录 一.发送纯文本内容 二.发送附件图片 三.发送纯文本附件 四.发送excel表格附件 前言: Python内置对SMTP的支持,可以发送纯文本邮件.HTML邮件以及带附件的邮件. Python对SMTP支持有smtplib和email两个模块,email负责构造邮件,smtplib负责发送邮件. 一.发送纯文本内容 代码如下: # 引入相应的模块 import smtplib from email.mime.text import MIMEText from email.mime.mult

  • python实现SMTP邮件发送功能

    一直想着给框架添加邮件发送功能.所以整理下python下邮件发送功能 首先python是支持邮件的发送.内置smtp库.支持发送纯文本.HTML及添加附件的邮件.之后是邮箱.像163.qq.新浪等邮箱默认关闭SMTP服务,需要我们手动打开,打开后通过发件人邮箱.授权密码 通过发件人的SMTP服务发送 代码如下: #!/usr/bin/env python # -*- coding: utf_8 -*- from email.mime.text import MIMEText from email

  • 如何使用Python自动生成报表并以邮件发送

    数据分析师肯定每天都被各种各样的数据数据报表搞得焦头烂额,老板的,运营的.产品的等等.而且大部分报表都是重复性的工作,这篇文章就是帮助大家如何用Python来实现报表的自动发送,解放你的劳动力,可以让你有时间去做更有意思的事情. 首先来介绍下实现自动报表要使用到的Python库: pymysql 一个可以连接MySQL实例并且实现增删改查功能的库 datetime Python标准库中自带的关于时间的库 openpyxl 一个可以读写07版以后的Excel文档(.xlsx格式也支持)的库 smt

  • Python自动化办公之邮件发送全过程详解

    使用Python实现自动化邮件发送,可以让你摆脱繁琐的重复性业务,可以节省非常多的时间.操作前配置(以较为复杂的QQ邮箱举例,其他邮箱操作类似) 单击设置-账号,滑倒下方协议处,开启IMAP/SMTP协议(IMAP,即Internet Message Access Protocol(互联网邮件访问协议),可以通过这种协议从邮件服务器上获取邮件的信息.下载邮件等.IMAP与POP类似,都是一种邮件获取协议.) (ps.开启需要验证) 记住端口号,后续写代码发送邮件时候需要: 生成授权码,前期配置完

  • python使用smtplib模块通过gmail实现邮件发送的方法

    本文实例讲述了python使用smtplib模块通过gmail实现邮件发送的方法.分享给大家供大家参考.具体实现方法如下: import smtplib from email.MIMEMultipart import MIMEMultipart from email.MIMEText import MIMEText fromaddr = 'fromaddr@gmail.com' toaddr = 'toaddr@gmail.com' text = 'test email message sent

  • python定时利用QQ邮件发送天气预报的实例

    大致介绍 好久没有写博客了,正好今天有时间把前几天写的利用python定时发送QQ邮件记录一下 1.首先利用request库去请求数据,天气预报使用的是和风天气的API(www.heweather.com/douments/api/s6/weather-forecast) 2.利用python的jinja2模块写一个html模板,用于展示数据 3.python的email构建邮件,smtplib发送邮件 4.最后使用crontab定时执行python脚本 涉及的具体知识可以去看文档,本文主要就是

  • 利用python实现简单的邮件发送客户端示例

    脚本过于简单,供学习和参考.主要了解一下smtplib库的使用和超时机制的实现.使用signal.alarm实现超时机制. #!/usr/bin/env python # -*- coding: utf-8 -*- import time import sys import logging import smtplib import socket import signal import ConfigParser from datetime import datetime from email

  • Python实现定时备份mysql数据库并把备份数据库邮件发送

    一.先来看备份mysql数据库的命令 mysqldump -u root --password=root --database abcDataBase > c:/abc_backup.sql 二.写Python程序 BackupsDB.py #!/usr/bin/python # -*- coding: UTF-8 -*- ''''' zhouzhongqing 备份数据库 ''' import os import time import sched import smtplib from em

随机推荐