百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python办公自动化-Excel合并同类项内容

off999 2024-12-17 15:42 31 浏览 0 评论

阅读本文大约需要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感谢您的支持!

相关推荐

微信一键恢复(微信一键恢复已删好友怎么操作)
  • 微信一键恢复(微信一键恢复已删好友怎么操作)
  • 微信一键恢复(微信一键恢复已删好友怎么操作)
  • 微信一键恢复(微信一键恢复已删好友怎么操作)
  • 微信一键恢复(微信一键恢复已删好友怎么操作)
win7系统序列号怎么查(win7电脑的序列号怎么查)

你可以在cmd命令行窗口中输入以下相关命令,可以得到你要的信息查找主板厂商输入:wmicBaseBoardgetManufacturer查找主板型号输入:wmicBaseBoardgetP...

台式电脑怎么看配置好坏(台式机怎么看配置参数哪里看好坏)

如何分辨电脑配置好坏第一看CPU,CPU从上到下可分为i7,i5,i3等,数字越高越好。第二看显卡和内存,显卡内存现在至少4G或者8G起步,越高越好,第三看硬盘是否是固态,固态要比机械的运行速度快...

下载软件安装不了(为什么下载软件安装不了)

    一:检查手机内存是否充足,如果内存太小,需要更换大容量的SD卡。  二:检查手机是否设置允许安装除手机自带应用商店以外的应用。  方法一:需要从手机自带应用商店下载。  ①点击手机桌面上的应用...

现在建议更新win11吗(应该升级win11吗)

鲁大师更新11靠谱的,他只是给你提供一个方便的升级渠道而已。升级以后能否正常使用,还要看你原来的系统是否是正版。如果原来的系统是正版,升级完成后,可以正常使用。如果原来的系统是盗版,也是可以升级的,只...

windows7旗舰版好用吗(win7旗舰版好用么)

win7旗舰版挺好使的不过现在可以选择更win10。Windows7旗舰版属于微软公司开发的Windows7操作系统系统系列中的功能最高级的版本,也被叫做终结版本,是为了取代WindowsXP...

2025年最好用的手机浏览器(2021最好的手机浏览器)

可以使用uc浏览器或者是QQ浏览器,最新版本都是带有Flash插件的,火狐浏览器手机版也是一开始拥有Flash插件。以下是详细介绍:  1、uc浏览器是阿里旗下的浏览器,只需要下载最新版,然后进去就可...

电脑一键还原系统在哪里(电脑一键还原系统怎么用)
  • 电脑一键还原系统在哪里(电脑一键还原系统怎么用)
  • 电脑一键还原系统在哪里(电脑一键还原系统怎么用)
  • 电脑一键还原系统在哪里(电脑一键还原系统怎么用)
  • 电脑一键还原系统在哪里(电脑一键还原系统怎么用)
纯净版win11在哪下载(在哪下win10纯净版)

Win11纯净版中,有一些常用的应用软件,包括但不限于以下几款:MicrosoftEdge:微软推出的新一代浏览器,支持多种设备,具备更快的加载速度和丰富的扩展功能。MicrosoftOffice...

电脑软件最全的应用商店(电脑软件最全的应用商店下载)
  • 电脑软件最全的应用商店(电脑软件最全的应用商店下载)
  • 电脑软件最全的应用商店(电脑软件最全的应用商店下载)
  • 电脑软件最全的应用商店(电脑软件最全的应用商店下载)
  • 电脑软件最全的应用商店(电脑软件最全的应用商店下载)
win7自带激活工具在哪个位置

恩,其实这些就是激活系统的工具,朋友可以通过计算机属性看看你的系统是不是激活了。如果没有的话,建议你使用OEM7F7那个,使用方法是右键,以管理员身份运行,然后点击开始体验正版,等下,重新启动系统...

无法激活因为无法连接到组织

 解决方法: 首先我们右键点击“开始菜单”,选择“WindowsPowerShell(管理员)”。 在windowsPowershell窗口中逐一输入如下三行命令,并回车键执行命令。 slmgr...

一个2tb的u盘多少钱(2tb优盘)

假的就算你买回来插到电脑上显示是2TB也没用,你复制东西到U盘里就会显示U盘已满不能复制,就算复制进去了也会有一部分不能使用。或者你买回来用360的U盘鉴定软件鉴定一下就知道真假了。还有就是你看看...

软件商店下载官方网站(软件商店正版软件下载)

软件商店安装的方法步骤如下:1.第一步,需要注册一个微软账户,然后点击桌面左下角的开始图标,然后在开始菜单中找到微软商店图标,点击进入。2.第二步,点击进入应用商店主页。3.第三步,在商店中搜索...

系统应用架构(系统应用架构有哪些)

一、目的不同:系统架构是对已确定的需求的技术实现构架、作好规划,运用成套、完整的工具,在规划的步骤下去完成任务。应用构架是描述了IT系统功能和技术实现内容的构架。二、实现方式不同:系统架构通过规划程序...

取消回复欢迎 发表评论: