如何用python批量发送工资条邮件
作者:vision_wang 时间:2021-03-07 10:53:09
工资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.set_debuglevel(1)
smtp_obj.login('vision.wangpc@foxmail.com', "tsjodbaab") # 腾讯邮箱,客户端登录使用授权码
这里有坑:邮箱登录的的账户密码有的邮箱是密码,有的是使用授权码,腾讯qq邮箱就是使用授权码
使用新浪邮箱时候,登录不上服务器,原因未知!
遍历sheet表,获取表头信息。
count = 0
for row in ws:
count += 1
if count == 1: # 表头信息读取一次即可
table_header = '<thead>'
for cell in row:
table_header += f'''<th >{cell.value}</th>'''
table_header += '</thead>'
读取excel第一行,构造表头,第一行只读取一次,所以加了一个计数变量.count
table_header
是构造工资条表头信息的html文本
读取每一行数据,获取员工姓名、邮箱以及工资条信息,构造邮件正文的完整内容!
else:
msg_context_data = '<tr>'
for cell in row: # 一次读取员工工资条
msg_context_data += f'''<td>{cell.value}</td>'''
msg_context_data += '</tr>'
mail = row[1].value
name = row[2].value
msg_context = f'''
<h3>{name},你好:</h3>
<p>请查收你2022-05月的工资条</p>
<table border="1px">
{table_header}
{msg_context_data}
</table>
'''
msg_context_data
是工资条信息那一行html格式的文本数据
每读取一行数据,发送一封邮件
msg = MIMEText(msg_context, 'html', 'GBK')
msg['from'] = Header('xx人力资源部', 'GBK')
msg['To'] = Header('name', 'GBK')
msg['Subject'] = Header('2022.5月工资条', 'GBK')
smtp_obj.sendmail('vision.wangpc@foxmail.com', mail, msg.as_string()) # 没读取一行信息发送一封邮件
总结反思:
这个小程序就是复习实践python发邮件以及简单的excel的处理,python的用处还是很大,也很贴近实际生活,有待多多发觉!
来源:https://blog.csdn.net/vision666/article/details/122688125
标签:python,邮箱,工资条
0
投稿
猜你喜欢
Python超简单容易上手的画图工具库(适合新手)
2021-12-06 04:05:23
再说淘宝的评价和信用机制
2008-07-10 12:43:00
《悟透JavaScript》感谢语
2008-11-12 12:59:00
Python3.10.4激活venv环境失败解决方法
2022-11-15 10:39:39
开发iPhone版校友录
2009-08-31 16:29:00
mysql4.1以上版本连接时出现Client does not support authentication protocol问题解决办法
2023-11-18 06:10:15
js经验分享 JavaScript反调试技巧
2023-07-13 07:53:04
如何使用Pytorch搭建模型
2022-07-18 10:34:27
Python使用PyYAML库读写yaml文件的方法
2021-03-26 03:53:32
Python教程之生产者消费者模式解析
2021-03-07 17:55:53
一场关于YUI3/jQuery的精彩辩论
2010-11-11 12:50:00
Django Admin实现上传图片校验功能
2021-12-12 02:27:03
Pandas 同元素多列去重的实例
2023-02-09 21:03:32
高性能网站建设指南:性能提升的14个原则
2011-07-14 16:04:54
基于Python编写一个简单的服务注册发现服务器
2022-06-11 20:23:31
python实现简单ftp客户端的方法
2023-12-14 20:07:31
asp如何准确地获得一个整数?
2010-07-07 12:25:00
Python实现简单2048小游戏
2023-08-13 00:19:18
轻松接触MaxDB和MySQL之间的协同性
2008-11-27 16:25:00
详解用python生成随机数的几种方法
2022-01-24 14:17:42