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合并后的结果返回。

相关推荐
fengyehongWorld2 小时前
Excel 超级表获取行列数据的方法
excel
WarPigs3 小时前
基于泛型+反射的Excel万能导表工具
unity·c#·excel·反射
城数派5 小时前
2005-2025年我国省市县三级的逐日地表温度数据(Shp/Excel格式)
数据分析·excel
王夏奇6 小时前
Python-对excel文件操作-pandas库
python·excel·pandas
E_ICEBLUE7 小时前
Excel 删除空白行的 5 种方法 【手动管理与 Python 自动化】
python·自动化·excel
身如柳絮随风扬7 小时前
Spring Boot文档导出(Word,Excel,PPT),导入(Excel)
spring boot·word·excel·ppt
陳土8 小时前
EXCEL重点函数
excel
海天一色y8 小时前
Vim 编程完全指南:从入门到精通
编辑器·vim·excel
softbangong8 小时前
888-Excel数据填充PPT工具
powerpoint·excel·办公自动化·自动化办公·excel数据处理·ppt批量生成·文档批量制作
城数派9 小时前
2005-2025年我国省市县三级的逐日露点温度数据(Shp/Excel格式)
excel