网站首页 > 技术文章 正文
阅读本文大约需要2分钟
主要内容:Excel办公自动化
适用人群:Python初学者,办公室人员,或有志从事数据分析工作的人员
准备内容:Anaconda
摘要
今天Officetouch为大家带来关于Python办公自动化入门的知识。不知大家有没有遇到过这样的问题:需要把Excel同类项的内容进行合并(比如上图左边“工号”相同的角色合并成右边这样用逗号隔开),我们可以在Excel上安装Power Query/Power Pivot插件来解决,但是操作有点繁琐,安装一个不常用的插件不说,还不太好理解,大家可以看下这种方式:
方案1、用Power Query的方式:(想用Python自动化解决方法,直接跳到方案3)
步骤1、安装Power Query插件;
步骤2、点击数据 — 自表格/区域,上传到PQ界面;
(如果上传后数据格式不是文本,需要先改一下数据类型)
步骤3、主页 — 分组依据,分组依据如图所示;
步骤4、将List.Sum([Invoice])改为Text.Combine([Invoice]。
点击确定后,可以看到发票一列显示Error,因为文本格式是无法求和的。改公式,将List.Sum([Invoice])改为Text.Combine([Invoice], "/"),然后按回车。
方案2、在Excel上用VB编程的方式:(想用Python自动化解决方法,直接跳到方案3)
原始数据如下,A列包含重复的姓名,B列是对应的不同数量或者说型号。需要将A列数据去除重复值,并且将B列的同一个人的数量合并在一个单元格里并用逗号分开。
步骤1、将AB列的抬头,复制到CD列;
步骤2、按Alt+F11进入VBE界面;
步骤3、选择【插入】-【模块】插入一个模块;
步骤4、在模块空白处粘贴下列代码:
Sub yy()
Dim Arr, i&, d, Myr&
Set d = CreateObject("Scripting.Dictionary")
[c2:d65535].Clear
Myr = [a65536].End(xlUp).Row
Arr = Range("a1:c" & Myr)
For i = 2 To UBound(Arr)
If Not d.exists(Arr(i, 1)) Then
d(Arr(i, 1)) = Arr(i, 2)
Else
d(Arr(i, 1)) = d(Arr(i, 1)) & "," & Arr(i, 2)
End If
Next
k = d.keys
t = d.items
[c2].Resize(d.Count, 1) = Application.Transpose(k)
[d2].Resize(d.Count, 1) = Application.Transpose(t)
End Su
步骤5、返回excel界面,点击【开发工具】,插入一个按钮;
步骤6、用鼠标左键在工作表中画出一个按钮,并指定宏至刚才插入的宏;
方案3、Python办公自动化的方式:
Officetouch今天为大家分享一个最简易的方法,从这个合并同类项内容开始,我们逐步学习办公自动化。原表(person_role.xlsx)如下:
步骤1、打开Anaconda-Spyder,粘贴如下代码,运行后打开“test.xlsx”就可以看到效果了:
import pandas as pd
df = pd.read_excel("person_role.xlsx")
df["角色"]=df["角色"].astype(str) #这一步在pycharm中是必要的
df1=df.groupby(["工号","姓名"]).apply(lambda x:[",".join(x["角色"])])
col1 = ["角色"]
df2 = pd.DataFrame(df1,columns=col1)
df2.to_excel("test.xlsx",sheet_name="sheet2")
是不是很神奇?1个步骤就搞定了,用Python办公自动化确实提高了效率!
结尾语
好了,今天大家学会如何用Python实现Excel合并同类项内容了吗?是不是激起了大家学习Python办公自动化的兴趣和斗志,Officetouch相信只要大家抱着解决工作和生活问题的决心,不久后我们就能成为职场高手。
如果觉得有用的话,请帮忙点赞、关注、收藏哦,Officetouch感谢您的支持!
猜你喜欢
- 2025-04-01 Python中docx与docxcompose批量合并多个Word文档并添加分页符
- 2025-04-01 Python连接西门子PLC(python读取plc数据)
- 2025-04-01 探索 Python 中合并两个字典的七种方法,找到最适合你的那一款!
- 2025-04-01 Python 字典合并、求和大作战,轻松搞定各路数据
- 2025-04-01 Python将两个或多个列表合并为一个列表的列表
- 2025-04-01 python合并excel工作表中的sheet页,第一列为索引,将某一列连接
- 2025-04-01 Python中endswith()函数的使用方法
- 2025-04-01 Python 连接三款流行的数据库(python用什么接口连数据库)
- 2025-04-01 无缝融合:使用 Python 和 PyFFmpeg 合并视频的完整指南
- 2025-04-01 7行Python代码,快速合并音频和视频文件!
- 264℃Python短文,Python中的嵌套条件语句(六)
- 263℃python笔记:for循环嵌套。end=""的作用,图形打印
- 261℃PythonNet:实现Python与.Net代码相互调用!
- 256℃Python操作Sqlserver数据库(多库同时异步执行:增删改查)
- 256℃Python实现字符串小写转大写并写入文件
- 116℃原来2025是完美的平方年,一起探索六种平方的算吧
- 96℃Python 和 JavaScript 终于联姻了!PythonMonkey 要火?
- 89℃Ollama v0.4.5-v0.4.7 更新集合:Ollama Python 库改进、新模型支持
- 最近发表
-
- 金母鸡量化教学场:pandas—数据挖掘的Python库
- 分享一个用于商业决策数据挖掘的python案例
- Python图像识别实战(二):批量图像读取和像素转换(附源码)
- 从小白到大神,这10个超实用的 Python 编程技巧不可少
- 太震撼!527页战略级Python机器学习实战,实用度碾压群书!附PDF
- 一篇文章带你解析Python进程(一篇文章带你解析python进程怎么写)
- 大数据分析师如何进行数据挖掘?大数据分析师丨 2025 年报考攻略
- UG编程第34节:浅谈机床坐标系(ug编程机床坐标系细节)
- 想入门Python?先狠下心来死磕这7个方向
- Python大屏看板最全教程之Pyecharts图表
- 标签列表
-
- python中类 (31)
- python 迭代 (34)
- python 小写 (35)
- python怎么输出 (33)
- python 日志 (35)
- python语音 (31)
- python 工程师 (34)
- python3 安装 (31)
- python音乐 (31)
- 安卓 python (32)
- python 小游戏 (32)
- python 安卓 (31)
- python聚类 (34)
- python向量 (31)
- python大全 (31)
- python次方 (33)
- python桌面 (32)
- python总结 (34)
- python浏览器 (32)
- python 请求 (32)
- python 前端 (32)
- python验证码 (33)
- python 题目 (32)
- python 文件写 (33)
- python中的用法 (32)