Python邮件处理:POP与SMTP
poplib简介
poplib 是Python 3中的官方邮件库,实现了POP的标准:RFC1939,用于邮件的收取。与之类似的还有imaplib 。
(注:本文仅拿pop举例)
poplib的使用方法,就是几步:
- 先创建一个
poplib.POP3
类的实例(如果使用SSL,则是poplib.POP3_SSL
类的实例) - 之后使用
user
、pass_
设置认证 - 再使用
list
获取邮件列表 - 根据列表序号,使用
retr
收取邮件。 - (可选)使用
delete
删除邮件。
另外,如果需要调试,可以使用类的set_debug
方法,打印详细的报文交互过程。
如:
def get_mail(host, port, is_ssl, is_debug, username, password):if is_ssl:server = poplib.POP3_SSL(host, port)else:server = poplib.POP3(host, port)# 开启debug模式,将会打印详细的报文交互过程,便于调试server.set_debuglevel(is_debug)if is_debug:print(server.getwelcome().decode('utf-8'))server.user(username)server.pass_(password)if is_debug:print('Messages: %s. Size: %s' % server.stat())resp, mails, octets = server.list()if is_debug:print(mails)for index in range(1, len(mails) + 1, 1):# 下文将自定义自定义函数,收取邮件if get_mail(server, index):server.dele(index)
解析邮件为EmailMessage
解析邮件的时候,可以使用Python 3的email 库。
我们使用email的parser.Parser类实例,把邮件内容解析成一个message.EmailMessage实例。
如:
def get_mail(server, index):resp, lines, octets = server.retr(index)if resp != b'+OK':raise Exceptioncontent = b'\r\n'.join(lines).decode('utf-8')msg = Parser().parsestr(content)return msg
获取邮件中的附件
如果我们需要获取邮件中的附件,可以进一步解析EmailMessage。
解析EmailMessage的时候,需要注意有的邮件文本也是以附件形式放入邮件中的。所以,需要判断附件的名字是不是message。
正文的文本有可能使用了非ASCII的编码,可以通过EmailMessage的get_charset
方法取得。如果取得失败,再通过ContentType域取得。
def guess_charset(msg): charset = msg.get_charset() if charset: return charset content_type = msg.get('Content-Type', '').lower() pos = content_type.find('charset=')if pos >= 0:remain = content_type[pos + 8:].strip() pos = remain.find(';') if pos >= 0: return remain[:pos] return remain return None
最后完整的解析代码如下:
from email.utils import parseraddr
from email.header import decode_headerdef save_attachment(path, msg):content_type = msg.get_content_type()content = msg.get_payload(decode=True)if content_type == 'text/plain' or content_type == 'text/html':charset = guess_charset(msg)if charset:content = content.decode(charset)else:content = content.decode('utf-8')with open(path) as fp:fp.write(content)def parse_message(msg)# 获取邮件主题subject = msg.get('Subject', '')# 获取发件人from_value, from_addr = parseaddr(msg.get('From', ''))# 获取收件人to_value, to_addr = parseaddr(msg.get('To', ''))# 判断是否有附件if msg.is_multipart():parts = msg.get_payload()for n, part in enumerate(parts):name = part.get_filename('message')if name == 'message':save_attachment('message', part)else:realname = decode_str(name)attapath = os.path.join(attachments_path, realname)save_attachment(attapath, part)else:save_attachment('message', msg)
使用smtplib发送邮件
发送邮件相对来说比收取简单,因为格式我们可以控制,只要采用最简单标准的就行了。
先生成一个EmailMessage。
def generate_message(subject, from, to, message, attchment_list):if len(attchment_list) == 0:message = MIMEText(message, 'plain', 'gb2312')else:message = MIMEMultipart()message.attach(MIMEText(message, 'plain', 'gb2312'))message['Subject'] = Header(subject, 'gb2312')message['From'] = frommessage['To'] = to# attachment_list,是一个列表,每一项是一个包含Content-Type与路径的字典。for att in attachment_list:add_attachment(message, att['content-type'], att['path'])return message
追加附件的实现如下:
def add_attachment(message, contenttype, path):# Content-Type一般是text/html这种格式appname, subtype = contenttype.split('/')# 取得文件名作为附件里文件的名字,加入附件EmailMessage的Header_dirname, basename = os.path.split(path)encodedname = Header(basename, 'gb2312').encode()att = MIMEBase(appname, subtype, name=encodedname)att.add_header('Content-Disposition', 'attachment', filename=encodedname)# 加入附件内容att.set_payload(open(path, 'rb').read(), 'base64')message.attach(att)
使用smtplib发送的过程,类似与poplib。
- 创建一个SMTP(或者SMTP_SSL)实例
- 连接服务端(connect)
- 登录服务端(login)
- 发送邮件(sendmail)
import smtplibdef smtp_send(host, port, is_ssl, username, password, sender, receivers, message):if is_ssl:server = smtplib.SMTP_SSL()else:server = smtplib.SMTP()server.connect(host=host, port=port)server.login(username, password)server.sendmail(sender, receivers, message.as_string())
相关文章:
Python邮件处理:POP与SMTP
poplib简介 poplib 是Python 3中的官方邮件库,实现了POP的标准:RFC1939,用于邮件的收取。与之类似的还有imaplib 。 (注:本文仅拿pop举例) poplib的使用方法,就是几步: 先创建一…...

什么是VR场景?VR与3D漫游到底有什么区别
在数字化时代,虚拟现实(Virtual Reality, 简称VR)场景与3D漫游作为两种前沿技术,改变着人们的生活方式和体验模式。通过计算机模拟真实或假想的场景,让用户仿佛身临其境,并能与虚拟环境进行互动。尽管VR场景…...

python学习day2:进制+码制+逻辑运算符
进制 Python 中的进制表示与转换 进制的基本概念 二进制、八进制、十进制、十六进制的定义与特点不同进制在计算机科学中的应用场景 Python 中的进制表示 二进制表示:使用 0b 前缀八进制表示:使用 0o 前缀十六进制表示:使用 0x 前缀示例…...

【分布式文件系统】FastDFS
1.简介 讲这个之前,相信很多人特别是学java的,肯定在做苍穹外卖的时候肯定接触过一个东西,叫做阿里云OSS,他们的功能都差不多,但是阿里云的这个是要付费的,而FastDFS是免费开源的,是由淘宝资深…...
14、自动配置【源码分析】-初始加载自动配置类
14、自动配置【源码分析】-初始加载自动配置类 Spring Boot的自动配置功能通过智能地加载和配置组件,极大地简化了应用的初始化过程。以下是初始加载自动配置类的详细原理: ### 1. 启动应用 当执行 SpringApplication.run() 方法启动Spring Boot应用时&a…...

word为章节标题添加自动编号
问题: 如何为word文档中的多级标题添加自动编号? 方法: 1、首先为文档各级标题设置格式样式,一级标题使用样式中的“标题 1”,二级标题使用“标题 2”,三级使用“标题 3”,也就是直接在开始—…...

无人机飞行间隔安全智能评估、安全风险评估
无人机空中安全飞行评估需结合改进碰撞模型、蒙特卡洛仿真、安全间隔反推及动态避障策略,通过多机型分类与实时数据融合,实现从理论建模到实际部署的全流程管控,为城市低空密集飞行提供安全保障。 需求 无人机飞行间隔安全智能评估 无人机…...
C++成员对象和封闭类
C++成员对象和封闭类详解 在C++中,成员对象是指一个类的成员变量,它本身是另一个类的对象。封闭类是包含这些成员对象的类。理解两者的关系和行为,对于构造函数、析构函数、初始化顺序以及内存布局等方面的理解非常重要。 1. 成员对象和封闭类的基本概念 成员对象 是一个类…...

【VLNs篇】03:VLMnav-端到端导航与视觉语言模型:将空间推理转化为问答
栏目内容论文标题End-to-End Navigation with Vision-Language Models: Transforming Spatial Reasoning into Question-Answering (端到端导航与视觉语言模型:将空间推理转化为问答)核心问题如何利用大型视觉语言模型(VLM)实现端到端的机器人…...

PCB设计实践(二十五)贴片电阻与插件电阻的全面解析:差异、演进与应用场景
一、基础结构与技术原理差异 物理结构差异 贴片电阻(SMD Resistor)采用表面贴装技术(SMT),其主体为扁平长方体或圆柱形结构,两端金属化电极直接与PCB焊盘接触。典型封装尺寸包括0402(1.00.5mm&a…...
知道不知道
以其昏昏使人昭昭,真正的傻子是自己。 昏昏沉沉,迷迷茫茫,无所适从,无所事事。 清醒与糊涂间交替,知道与不知道间轮循。 在哪里?到哪里? 世界上事物对于我们:知道知道的&…...
文章记单词 | 第106篇(六级)
一,单词释义 branch /brntʃ/ n. 树枝;分支;分部 v. 分支;分岔proceeding /prəˈsiːdɪŋ/ n. 程序;进程;(复数)会议记录academy /əˈkdəmi/ n. 学院;研究院&#x…...
SpringBoot项目中Redis的使用
在Spring Boot项目中使用Redis作为缓存或数据存储是非常常见的场景。以下是详细的实现步骤和示例代码: 一、添加依赖 在pom.xml中添加Spring Data Redis依赖: <dependency><groupId>org.springframework.boot</groupId><artifac…...

Canvas设计图片编辑器全讲解(一)Canvas基础(万字图文讲解)
一、前序 近两年AI发展太过迅速,各类AI产品层出不穷,AI绘图/AI工作流/AI视频等平台的蓬勃发展,促使图片/视频等复杂内容的创作更加简单,让更多普通人有了图片和视频创作的机会。另一方面用户内容消费也逐渐向图片和视频倾斜。在“…...

利用Qt绘图随机生成带多种干扰信息的数字图片
背景 在学习AutoML或ML的过程中,需要一些图片类型的数据做分类预测训练,于是想到尝试最简单的数字识别,且单个数字的识别,也就是y的取值只有10种可能,即0到9。 以下参考代码分别考虑了数字字体的大小、数字颜色的深浅…...

STM32——从点灯到传感器控制
STM32基础外设开发:从点灯到传感器控制 一、前言 本篇文章总结STM32F10x系列基础外设开发实例,涵盖GPIO控制、按键检测、传感器应用等。所有代码基于标准库开发,适合STM32初学者参考。 二、硬件准备 STM32F10x系列开发板LED模块有源蜂鸣器…...

java day14
接昨天,响应 响应 就是我们在处理请求的时候,里面的return 其实方法里面写的return的返回平常的什么字符串啊什么等等;这些东西都是直接返回;如果是一个对象的话,我们会按json的格式返回; 这些都依赖于一…...

Tailwind css实战,基于Kooboo构建AI对话框页面(一)
在当今数字化时代,AI 助手已成为网站和应用不可或缺的一部分。本文将带你一步步使用 Tailwind CSS 和 Kooboo 构建一个现代化的 AI 对话界面框。 一、选择 Kooboo平台 的核心优势 智能提示:在输入 class 属性时,会自动触发 Tailwind CSS 规则…...

重塑数学边界:人工智能如何引领数学研究的新纪元
目录 一、人工智能如何重新定义数学研究的边界 (一)数学与AI的关系:从基础理论到创新思维的回馈 (二)AI的创造力:突破传统推理的局限 (三)AI对数学研究的潜在贡献:创…...

docker部署并测试翻译模型-CSANMT连续语义增强机器翻译
1.模型选择CSANMT-Translation模型: 2.修改docker-compose.yml文件,重新定义模型缓存路径和存储路径 其中MODELSCOPE_CACHE指定了模型的下载路径。 3.运行docker compose up -d --build,提示出现报错:Error response from daemon…...
蓝桥杯2025.5.23每日一题-儿童数
儿童数 若一个正整数 n n n 满足 n 61 n^{61} n61 整除 2024 ! 2024! 2024!,即 2024 ! 2024! 2024! 除以 n 61 n^{61} n61 的余数为 0 0 0,则称 n n n 为儿童数。 现在,请你计算在区间 [ 1 , ∞ ) [1, \infty) [1,∞) 内一共有多少…...

Spring Boot项目配置核心 - pom.xml的依赖管理与构建优化
基础架构 <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVe…...

告别手抖困扰:全方位健康护理指南
手抖,医学上称为震颤,是常见的身体症状,可能由多种原因引发,了解其成因并采取科学护理措施,对改善症状、维护健康至关重要。 生理性手抖往往因情绪激动、过度劳累、大量饮用咖啡或酒精等引起,这种手抖通常较…...

图解深度学习 - 特征工程(DL和ML的核心差异)
前言 深度学习通过自动化特征提取,简化了机器学习工作流程,它让解决问题变得更加简单。因为深度学习将特征工程完全自动化,而特征工程曾经是机器学习工作流程中最关键的一步。 一、机器学习特征工程 机器学习为什么需要特征工程(…...
《短线操盘跟庄关键技术》速读笔记
文章目录 书籍信息概览基础技术及实战运用基本趋势及操盘策略陷阱的识别和规避短线实战选股实战买点分析实战卖点分析 书籍信息 书名:《短线操盘跟庄关键技术》 作者:明发 概览 基础技术及实战运用 技术分析的原理及特点:以市场行为&#…...

Datacom-hcia~Datacom-hcie学习笔记索引
hcia VLAN工作原理实验案例(超详细)https://blog.csdn.net/Fanmeang/article/details/145855768?spm1001.2014.3001.5502 交换机工作原理实验案例https://blog.csdn.net/Fanmeang/article/details/145802382?spm1001.2014.3001.5502 ARP理论实验案例(超详细&am…...
Oracle 中 SHRINK 与 MOVE 操作的比较
Oracle 中 SHRINK 与 MOVE 操作的比较 在 Oracle 数据库中,SHRINK 和 MOVE 都是用于重组表和索引以减少空间碎片的重要操作,但它们在实现方式和适用场景上有显著区别。 SHRINK 操作 基本语法 ALTER TABLE table_name SHRINK SPACE [COMPACT] [CASCAD…...

受不了github的网络限制了,我开源了一个图床工具 gitee-spring-boot-starter
嗨嗨嗨~ 我老马又又来了!!!上次写了一篇我开源了一款阿里云OSS的spring-boot-starter,然后买的资源包到期了,后面又想白(开)嫖(源)的路子,首先想到了使用gith…...
【Python 基础与实战】从基础语法到项目应用的全流程解析
(1)列表和元组的区别是什么?如何从列表创建元组?如何从元组创建列表? 列表和元组的区别: 可变性:列表是可变的,即可以对列表进行元素的增、删、改操作。例如,可以使用append()方法添加元素,r…...

2025年医美行业报告60+份汇总解读 | 附 PDF 下载
原文链接:https://tecdat.cn/?p42122 医美行业在消费升级与技术迭代的双重驱动下,已从边缘市场逐步走向主流。数据显示,2024 年中国医美市场规模突破 3000 亿元,年复合增长率达 15%,但行业仍面临正品率不足、区域发展…...