我们专注攀枝花网站设计 攀枝花网站制作 攀枝花网站建设
成都网站建设公司服务热线:400-028-6601

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

如何用Python​实现按姓名拆分Excel为单独文件并自动发给相应联系人

本篇内容介绍了“如何用Python实现按姓名拆分Excel为单独文件并自动发给相应联系人”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

创新互联建站于2013年创立,是专业互联网技术服务公司,拥有项目成都网站建设、网站建设网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元东光做网站,已为上家服务,为东光各地企业和个人服务,联系电话:028-86922220

一、前言

最近遇到一个需求:

  • 把员工信息汇总表excel,按员工姓名拆分成单独的excel,新excel以员工姓名命名,里面第一行是表头,第二行是员工信息。

  • 然后把excel通过微信单独发送给每位员工。

这个需求适用于发送月度工资表、学校学生信息统计等场景。

二、准备环境

1、请适用python 3.8.9 64位版本

其他版本在安装python-office库时会遇到各种问题,解决起来费时费力,建议直接使用python 3.8.9 64位版本,只需要在pycharm上搭建一个新环境,就可以轻松安装使用了。

2、安装python-office

pip install python-office

3、还会使用openpyxl这个库,用来处理excel。

三、思路分析

1、读取excel

openpyxl库的load_workbook()读取相应的表格,表单和单元格都用列表的形式使用就行,例如['Sheet1'].['B1']

2、删除excel不用的行

openpyxl库的删除整行命令是ws.delete_rows(),括号中输入行号,删除行时要注意从后往前删除,否则行号会出现错误:

比如删除了第二行后要删第三行,这时第三行已经变成了第二行,给删除造成麻烦,从后往前删就不会出现这个问题。

这里会用到最大行,命令为ws.max_row,接着用for遍历,需要倒着数,for i in range(ws.max_row, 1, -1),这样就从最后一行开始遍历,一直遍历到第二行,把不想要的用ws.delete_rows(i)删除就行。

3、保存成单独excel。

wb.save(),括号中写新的文件名

4、利用python-office库发送微信消息。

只需要用到一行命令,简单背后的复杂都由python-office库的开发者帮我们封装好了。

office.wechat.send_file(who=, file=),分别在括号里写上微信昵称和文件地址。

四、代码展示

上代码~

import openpyxl, office #导入两个库,第一个处理excel,第二个用到微信发消息功能,第二个库还有很多强大便捷的功能。
 
wb = openpyxl.load_workbook('C:/CoderWanFeng/./././???.xlsx') #括号中写汇总文件地址
ws = wb['Sheet1']              #获取excel表单
Names = ws['B']                #获取表单中第二列,我的表单第二列是微信昵称,可以根据实际进行调整
max_row = ws.max_row           #获取excel的最大行数
 
for Name in Names:             #第5行代码获得的昵称需要遍历
    Name = Name.value          #遍历出来的是元祖,需要用value进行取值
    if Name == '程序员晚枫':    #我的excel B1单元格写的是程序员晚枫,大家可以根据实际调整
        continue
    else:
        wb = openpyxl.load_workbook('C:/Users/./././???.xlsx')
        ws = wb['Sheet1']
        for j in range(max_row, 1, -1):   #倒着遍历,方便删除时不错序
            if ws[f'B{j}'].value != Name:
                ws.delete_rows(j)         #删除行
        file_path = f'C:/Users/./././{Name}.xlsx'  #重命名
        wb.save(file_path)  #保存excel
        office.wechat.send_file(who=Name, file=file_path)  #通过微信发送文件,分别在括号里写上微信昵称和文件地址。

“如何用Python实现按姓名拆分Excel为单独文件并自动发给相应联系人”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!


当前标题:如何用Python​实现按姓名拆分Excel为单独文件并自动发给相应联系人
文章分享:http://mswzjz.cn/article/ipscpp.html

其他资讯