Python办公自动化smtplib实现自动发送邮件

news2025/1/10 1:24:12

学好python自动化,走遍天下都不怕!!

        今天主要学习如何利用python自动化分析处理数据并以附件形式发送邮箱。需要安装配置python的运行环境,以及电脑支持Excel文件,有可以正常使用的邮箱。还需要用到python的第三方模块 xlrdxlsxwrite 和 smtplib 模块。学习的过程也是探索的过程,也欢迎正在学习python的小伙伴参考探讨交流,如果发现有问题请评论区留言,感谢。

主要实现过程:1.xlrd 读取excel数据  2.xlsxwrite生成就业数据图表 3.smtplib发送附件邮件

 

目录

一、读取Excel数据 

1.demo.xls数据

 2.新建python文件并读取excel数据

二、写入excel数据并生成图表

三、smtplib发送附件邮件


一、读取Excel数据 

需要导入的模块(没下载的需要先安装下)都放在下面代码里了:

# 导入xlrd|xlsxwriter|smtplib模块 
import xlrd  # 读取excel数据
import xlsxwriter #写入excel数据
import smtplib  # 发送邮件
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.mime.application import MIMEApplication
1.demo.xls数据

把我们提前准好的abc三个班级的就业薪资表demo.xls数据,导入项目中:

关于如何新建python项目前面都总结过啦。

 2.新建python文件并读取excel数据

这里我们新建xlswrite.py 文件,并且读取excel数据,拿到三个班级的信息数据表计算出各班级的平均薪资。然后把班级名称和对应的平均薪资数据添加到classdata中。

#1.读取excel文件
data = xlrd.open_workbook('demo.xls')
classdata = []

for sheet in data.sheets():
    obj = {'name':sheet.name,'avgpay':0}
    sum = 0 # 存储薪资
    for i in range(sheet.nrows):
        if i>1:
            sum += float(sheet.cell(i,5).value) 
    obj['avgpay'] = sum/(sheet.nrows-2)      
    classdata.append(obj)
print(classdata) 

 我们执行文件打印classdata的数据信息。可以看到我们已经成功获取到班级以及对应的平均薪资数据并且存放到classdata变量中。现在把数据写入另一个excel表中。

二、写入excel数据并生成图表

现在我们新建一个excel表,把班级以及平均薪资数据存放到新的excel表中,并且向新的excel表中插入图表数据。

# 2.写入excel数据
workbook = xlsxwriter.Workbook('newdemo.xls')
sheet = workbook.add_worksheet() # 创建工作表
# 写入班级数据
nameinfo = []
payinfo = []
for item in classdata:
    nameinfo.append(item['name'])
    payinfo.append(item['avgpay'])
sheet.write_column('A1',nameinfo)
sheet.write_column('B1',payinfo)

# 写入图表
chart = workbook.add_chart({'type':'column'})
# 标题
chart.set_title({'name':'平均就业薪资表'})
# 数据源
chart.add_series({
    'name':'班级',
    'categories':'=Sheet1!$A$1:$A$3',
    'values':'=Sheet1!$B$1:$B$3'
})
sheet.insert_chart('A7',chart)
workbook.close() #关闭文档

三、smtplib发送附件邮件

现在我们已经处理好就业薪资的数据以及对应的图表信息,下一步就是发送邮件,发送邮件需要准备发件人邮箱的主机地址、发件人邮箱、发件人授权码(需要开启smtp服务获取)、收件人邮箱以及附件信息。

授权码获取:需要短信验证一下。

 

 

# 3.发送邮箱  qabh******ugfgba  在第三方客户端登录时,密码框请输入以下授权码
host_server = 'smtp.qq.com' #主机地址
# 发件人邮箱
sender = '****8381@qq.com'
# 发件人授权码
code = 'qabh******ugfgba'
#收件人邮箱
user1 = '1*******51@163.com'

# 准备接收数据
# 邮件标题
mail_title = '高校平均就业薪资!!!!'
# 内容
mail_content = '1月份平均就业薪资,详见附件'
# 构建附件
attachment = MIMEApplication(open('newdemo.xls','rb').read())
attachment.add_header('Content-Disposition','attachment',filename='data.xls')

#smtp
smtp = smtplib.SMTP(host_server)
# 登录
smtp.login(sender,code)
# 发送
# 带附件的实例
msg = MIMEMultipart()
msg['Subject'] = mail_title
msg['From'] = sender
msg['To'] = user1
msg.attach(MIMEText(mail_content))
msg.attach(attachment)
smtp.sendmail(sender,user1,msg.as_string())

 这里是qq邮箱向163邮箱发送邮件。我们设置好邮件标题以及内容和附件信息后执行文件运行项目后,可以看到已经成功发送到163邮箱了,并且可以下载附件并查看。

PS D:\CODE\VSCODE\python\demo> python xlsxwrite.py

 咦 这里在核对数据的时候突然发现B班C班两个班数据竟然一样,但是excel数据是不一样的,于是一步一步向上查看数据源,发现都是一样的,直到找到读取excel数据表的数据都是一样的。奇怪了,于是打开项目中的excel数据确实数据是一样的,因为b班和c班的数据修改了之后忘记重新刷新数据换成修改之后的excel数据了。

 excel数据更新之后重新执行文件,发现数据正常了。

现在我们已经能成功获取到excel文件的数据,并且进行分析处理数据,最后把处理后的数据以附件的形式自动发送邮箱。

更多python内容:

python安装配置运行环境 | python爬虫获取数据 | python自动生成ppt分析报告 |

pythonl实现word办公自动化

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2069203.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

剧本杀门店预约小程序,提高消费者体验

当下,剧本杀行业一直处于活跃的状态,不管是线下聚会还是休闲娱乐,剧本杀游戏都是消费者的选择,剧本杀市场具有非常大的发展前景。 剧本杀门店预约系统是一个高效、便捷的游戏预约方式,能够帮助消费者便捷预约&#xf…

基于ssm的爱心捐赠管理系统的设计与实现(论文+源码)_kaic

摘 要 在互联网高速发展的现在,许多的办公与应用从传统的实体办理变为了在线处理。网购与网淘商品的浏览也从大街小巷变为了在线预览,从而使网上用户更好地对物品产生客观、全面立体的认知,并且对物品的对比也更加的省时省力。 爱心捐赠管…

一个简单的springboot项目(有源码)

开发一个springboot项目 代码迭代整合工具 gitee建模意义程序处理方式开发功能的步骤web服务网络状态码 web应用的开发分层springboot的作用 springboot框架搭建框架中各组件作用框架的演变如何提取hive中的表结构创建springboot 工程的引导模版 要选择aliyun ,否则…

java ssl使用自定义证书或忽略证书

1.证书错误 Caused by: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target 2.生成客户端证书 openssl x509 -in <(openssl s_client -connect 192.168.11.19:8101 -prexit 2>/dev/null) -ou…

linux neo4j 切换知识图谱

neo4j 安装 linux neo4j的安装可以浏览这篇文章&#xff1a; ubuntu sudo apt-get install neo4j 配置安装与设置远程访问 引言 如果你是window用户&#xff0c;直接下载桌面版进行安装与使用即可&#xff1b; 我有一台linux的服务器&#xff0c;想部署在上面&#xff0c;不…

UE5.4内容示例(5)UI_CommonUI - 学习笔记

https://www.unrealengine.com/marketplace/zh-CN/product/content-examples 《内容示例》是学习UE5的基础示例&#xff0c;可以用此熟悉一遍UE5的功能 UI_CommonUI可以看这个视频学习&#xff0c;此插件处于Beta状态&#xff0c;应用UI游戏方面&#xff0c;支持手柄等多输入端…

打饭-GYM

打饭 我还不信了&#xff0c;手动模拟一遍 再来了好看一点的图 ji12345a[i]21341120x3f0x3f0x3f0x3f0x3f114220x3f0x3f0x3f0x3f103520x3f0x3f0x3f0x3f9min(332,42)4020x3f0x3f0x3f8min(332,35)min(332,40)3190x3f0x3f7min(262,33)332490x3f0x3f6min(172,33)3120x3f0x3f0x3f5min…

【前端基础篇】JavaScript基础介绍

文章目录 前言初始JavaScriptJavaScript是什么发展历史JavaScript和HTML和CSS之间的关系JavaScript的运行过程JavaScript的组成 JavaScript的书写形式行内式内嵌式外部式注释 输入输出基础语法变量数据类型 运算符 JavaScript对象对象new关键字 常用对象数组创建数组数组操作函…

电影票api接口对接开发过程中需要注意什么?

电影票API接口对接过程需要考虑以下几个关键点&#xff1a; 1.了解API接口基础&#xff1a; 获取接口文档&#xff0c;理解其结构、请求方式、参数和返回数据格式。 2.接入流程&#xff1a; 使用API密钥或令牌进行身份验证。利用沙箱环境无风险测试。选择合适的编程语言实现…

Centos LVM磁盘合并方法

Centos LVM磁盘合并方法 使用fdisk -l命令查看机器增加了2块物理磁盘&#xff0c;一块40G另一块50G 需要将这两块盘的空间合并在一起&#xff0c;而且还需要动态扩展即在不关机的情况下操作 使用pvcreate将两块新增的物理磁盘加入物理卷 [rootlocalhost ~]# pvcreate /dev/sdb…

6G网络的关键技术、应用前景与挑战并存的科技征途

移动通信技术正以前所未有的速度迭代更新&#xff0c;而6G技术的研发与商用化进程渐渐成为了当前科技领域的热点与焦点。在5G技术尚未完全普及的今天&#xff0c;全球各国已纷纷将目光投向了更加充满想象的6G网络时代。本文将探讨全球6G研发的最新进展&#xff0c;特别是欧盟与…

Webots与ROS1、ROS2接口变迁-2024-

三大免费仿真器CoppeliaSim、Gazebo和Webots。 Gazebo接口总结&#xff1a; Gazebo与ROS1、ROS2接口变迁-2005-2024--CSDN博客 缺点&#xff1a;版本绑定策略 早期webots版本和ros版本绑定 后期&#xff0c;webots接口最新版本和ros特定版本最匹配。 例如&#xff1a; 最好按…

Ubuntu 中 SSH 服务的配置与原理详解

目录 1. 基本知识2. 配置步骤 1. 基本知识 一种用于在不安全的网络上安全登录和执行命令的协议 通过加密的方式保护通信数据&#xff0c;确保在传输过程中不被窃取或篡改 SSH 常用于远程登录服务器、传输文件以及执行命令 SSH 原理 公钥和私钥&#xff1a;SSH 使用公钥加密来…

UEFI 01记: 开发环境 在 ubuntu22 中搭建 edk2 开发环境并运行简单示例

https://uefi.org 1&#xff0c;预备环境 $ sudo apt install uuid-dev $ sudo apt install nasm $ sudo apt install bison flex $ sudo apt install build-essential $ sudo apt-get install x11proto-xext-dev $ sudo apt-get install libx11-dev $ sudo apt-get install l…

C语言回调函数进阶篇:全面总结与实战技巧

在C语言的编程世界中&#xff0c;回调函数是一种极其重要的概念。它提供了一种灵活的方式来编写可扩展和模块化的代码。本文将带你深入理解回调函数的原理&#xff0c;并通过一系列案例&#xff0c;系统且全面地总结回调函数的使用技巧。 一、回调函数解析 1.什么是回调函数&…

实战教程:Python实现高校爬虫,运用协同过滤与k-means算法进行专业评分分析

&#x1f393; 作者&#xff1a;计算机毕设小月哥 | 软件开发专家 &#x1f5a5;️ 简介&#xff1a;8年计算机软件程序开发经验。精通Java、Python、微信小程序、安卓、大数据、PHP、.NET|C#、Golang等技术栈。 &#x1f6e0;️ 专业服务 &#x1f6e0;️ 需求定制化开发源码提…

【工具】复制网页为markdown的浏览器插件

本文首发于 ❄️慕雪的寒舍 说明 如果您需要转载或者想保存他人的文章。可以使用一个油猴插件&#xff0c;快速将网站页面复制为markdown&#xff08;以下简称md&#xff09;。 只要目标网站是支持md语法&#xff08;大部分博客站点都是支持的&#xff09;那么复制下来的效果…

利用VirtualBox安装CentOS系统

博主这次用VirtualBox虚拟机安装CentOS系统。无论是大小型项目都是要发布到云主机上面&#xff0c;必然要用到Linux系统&#xff0c;有的人的本地电脑硬件配置不高&#xff0c;没有办法运行数据库集群&#xff0c;所以只能借助云主机。毕竟云主机也是Linux系统&#xff0c;大家…

程序员的日常挑战:如何在编码工作与持续学习之间找到平衡?

文章目录 每日一句正能量前言高效编码习惯与时间管理技巧高效编码习惯时间管理技巧 提升式学习的策略职业发展与个人成长的和谐共生职业发展的不同阶段及其技能要求如何在工作中寻找自我提升的学习机会分享个人成长的故事与经验 后记 每日一句正能量 黎明时怀着飞扬的心醒来&am…

Unity(2022.3.38LTS) - 2D刚体

目录 一.简介 二.组件详细介绍 2D刚体 类型介绍 三. 刚体的简单使用 一.简介 2D 物理系统为开发者提供了强大的工具来模拟和控制二维游戏中的物理行为。 A、基本概念 刚体&#xff08;Rigidbody 2D&#xff09; 刚体组件用于赋予游戏对象物理属性&#xff0c;使其能够受…