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

相关推荐
东方佑5 小时前
基于FastAPI与LangChain的Excel智能数据分析API开发实践
langchain·excel·fastapi
许泽宇的技术分享5 小时前
当Excel遇上大语言模型:ExcelAgentTemplate架构深度剖析与实战指南
语言模型·架构·excel
gihigo19986 小时前
基于MATLAB的Excel文件批量读取与循环处理
matlab·excel
CodeCraft Studio16 小时前
Excel处理控件Aspose.Cells教程:使用 Python 将 HTML 转换为 Excel
python·html·excel·aspose·aspose.cells·html转excel
Leo6553516 小时前
Excel 读取阶段就去掉换行
excel
小镇学者17 小时前
【PHP】利用 xlswriter 扩展导出的Excel文件报错问题
php·excel
程序员杰哥18 小时前
Pytest与Unittest测试框架对比
自动化测试·软件测试·python·测试工具·测试用例·excel·pytest
cehuishi952718 小时前
excel中关联word邮件合并使用
word·excel·批量打印·邮件合并
曾令胜1 天前
excel导出使用arthas动态追踪方法调用耗时后性能优化的过程
spring·性能优化·excel
我命由我123451 天前
Excel - Excel 列出一列中所有不重复数据
经验分享·学习·职场和发展·word·powerpoint·excel·职场发展