Excel 将非分组列的数据移到同一行

例题描述和简单分析

有 Excel 数据如下所示:

|--------------|-----------|---------------|--------------|
| Account Name | Join Date | Other Columns | Package |
| Account 1 | 2001/1/19 | Data | Main Package |
| Account 1 | 2001/1/19 | Data | Bolt On |
| Account 1 | 2001/1/19 | Data | Add on |
| Account 2 | 2001/1/18 | Data | Main Package |
| Account 3 | 2001/1/17 | Data | Main Package |
| Account 3 | 2001/1/17 | Data | Add on |
| Account 4 | 2001/1/19 | Data | Main Package |

需要按 ID 分组汇总其余列,结果如下:

|--------------|------------|---------------|--------------|------------|------------|
| Account Name | Join Date | Other Columns | Package | Extra Item | Extra Item |
| Account 1 | 2001-01-19 | Data | Main Package | Bolt On | Add on |
| Account 2 | 2001-01-18 | Data | Main Package | | |
| Account 3 | 2001-01-17 | Data | Main Package | Add on | |
| Account 4 | 2001/1/19 | Data | Main Package | | |

解法及简要说明

使用插件 SPL XLL

在空白单元格填写公式:

=spl("=((a=?.m(2:).group(~(1)).(if(~.len()>1,~=~.m(1)|~.m(2:).(~(4)),~=~.m(1))),b=?.m(1).pad(""Extra Item"",a.max(~.len())),[b]|a))",A1:D8)

如图:

返回结果:

简要说明:

a: 取第二行开始的数据部分,按第一列(Account Name)分组,若组内数据行数大于 1,则把从第二行开始的第四列(Package)依次拼接到第一行数据的尾部,否则取组内的第一条数据。

b: 用串 "Extra Item" 将第一行(表头)补足到和数据部分的最大列数一样长。

最后将表头b与数据a合并后的结果返回。

相关推荐
葡萄城技术团队1 天前
从100秒到10秒的性能优化,你真的掌握 Excel 的使用技巧了吗?
excel
QQ3596773452 天前
ArcGIS Pro实现基于 Excel 表格批量创建标准地理数据库(GDB)——高效数据库建库解决方案
数据库·arcgis·excel
星空的资源小屋4 天前
Digital Clock 4,一款免费的个性化桌面数字时钟
stm32·单片机·嵌入式硬件·电脑·excel
揭老师高效办公4 天前
在Excel和WPS表格中批量删除数据区域的批注
excel·wps表格
我是zxb4 天前
EasyExcel:快速读写Excel的工具类
数据库·oracle·excel
辣香牛肉面4 天前
[Windows] 搜索文本2.6.2(从word、wps、excel、pdf和txt文件中查找文本的工具)
word·excel·wps·搜索文本
ljf88384 天前
Java导出复杂excel,自定义excel导出
java·开发语言·excel
tebukaopu1484 天前
json文件转excel
json·excel
shizidushu4 天前
How to work with merged cells in Excel with `openpyxl` in Python?
python·microsoft·excel·openpyxl
Eiceblue5 天前
使用 C# 设置 Excel 单元格格式
开发语言·后端·c#·.net·excel