当前位置: 首页 > news >正文

python提取邮件的附件,以excel为例

配置邮箱、读取基本的邮件内容请参考:python读取并解析邮箱邮件,读取邮件主题、内容、时间

以excel为例:

  1. 获取邮件:
	email_value_config = {'imap_server': 'imap.exmail.qq.com', 'username': 'xxxx@xxxx.com', 'password': 'xxxxx', }# 连接到邮箱服务器email_server = imaplib.IMAP4_SSL(email_value_config['imap_server']) # 这样就已经链接到目标邮箱了email_server.login(email_value_config["username"], email_value_config['password']) # 这里登录email_server.select('INBOX')
  1. 提取数据需要使用:
	part.get_payload(decode=True)
  1. 写入本地文件时,使用:
	file_name = str(email.header.make_header(email.header.decode_header(part.get_filename()))) # 直接解析文件名,文件名会是balabala.xlsxwith open(file_name, "wb") as save_file:save_file.write(part.get_payload(decode=True))

示例代码

import imaplib
import email
from loguru import loggerdef parse_body(message):"""解析邮件/信体"""for part in message.walk():if not part.is_multipart():  # 这里要判断是否是multipart,用来判断附件是一个message列表file_name = part.get_filename()  # 附件需要有文件名if file_name:file_name = str(email.header.make_header(email.header.decode_header(part.get_filename()))) # 直接解析文件名,如果是excel,会在文件名中以.xlsx或.xls为后缀if not ((".xls" in file_name) or (".xlsx" in file_name)):  # 根据后缀判断附件是一个excelcontinuelogger.debug(f"准备保存文件 {file_name}")with open(file_name, "wb") as save_file: # 这里就是写入文件了save_file.write(part.get_payload(decode=True))logger.success(f"保存excel完成 {file_name}")def main():email_value_config = {'imap_server': 'imap.exmail.qq.com', 'username': 'xxxx@xxxx.com', 'password': 'xxxxx', }# 连接到邮箱服务器email_server = imaplib.IMAP4_SSL(email_value_config['imap_server']) # 这样就已经链接到目标邮箱了email_server.login(email_value_config["username"], email_value_config['password']) # 这里登录email_server.select('INBOX')# 选择收件箱_typ, _search_data = email_server.search(None, 'ALL')# 开始解析mailidlist = _search_data[0].split()  # 转成标准列表,获得所有邮件的IDprint(f'一共解析邮件数量:{len(mailidlist)}')# 解析内容for mail_id in mailidlist:result, data = email_server.fetch(mail_id, '(RFC822)')  # 通过邮件id获取邮件email_info = email.message_from_bytes(data[0][1])  # 邮件内容(未解析)parse_body(email_info)email_server.close()email_server.logout()if __name__ == '__main__':main()
http://www.lryc.cn/news/149000.html

相关文章:

  • ZooKeeper技术内幕
  • 乱糟糟的YOLOv8-detect和pose训练自己的数据集
  • 【Nginx】Nginx $remote_addr和$proxy_add_x_forwarded_for变量详解
  • MySQL自动删除binlog日志
  • C++ 文件和流
  • 案例分享:西河水库安全监测信息化系统实施方案
  • 使用Angular和MongoDB来构建具有登录功能的博客应用程序
  • ChatGPT 与前端技术实现制作大屏可视化
  • 视频监控/视频云存储EasyCVR平台接入华为ivs3800平台提示400报错,如何解决?
  • c++基础数据结构
  • 微服务-sentinel详解
  • 【MTK平台】根据kernel log分析wifi 连接的时候流程
  • 【SpringBoot】两种配置文件, 详解 properties 和 yml 的语法格式, 使用方式, 读取配置
  • 基于微信小程序的文化宣传平台的设计与实现(Java+spring boot+微信小程序+MySQL)
  • 一款windows的终端神奇,类似mac的iTem2
  • illegal cyclic inheritance involving trait Iterable_2种解决方式
  • 探秘二叉树后序遍历:从叶子到根的深度之旅
  • 2023全国大学生数学建模A题思路+模型+代码+论文(比赛开始后持续更新)
  • 从输入URL到页面展示过程:深入解析网络请求与渲染
  • Go 使用 Gorm 将操作信息集成到链路跟踪 Jaeger,进行增删改查使用举例,并做可视化UI界面展示(附源码)
  • 【JavaScript精通之道】掌握数据遍历:解锁现代化遍历方法,提升开发效率!
  • opencv android sdk 使用中的问题
  • 《向量数据库指南》——向量数据库与人工智能是一对“双生子
  • WebSocket协议
  • Spring 事务是什么 ?事务的传播机制?
  • 黑马最新MybatisPlus教程!帮你实现快速开发
  • 秒杀场景下用乐观锁解决超卖问题
  • 技术实践|Hive数据迁移干货分享
  • The remote endpoint was in state [TEXT_FULL_WRITING]
  • 微信小程序ios下,border显示不全兼容问题解决