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

wps/excel函数技巧:lambda+group+textjoin逆透视再聚合

itomcoil 2025-03-04 12:44 7 浏览


如图A列至F列为统计函数列,其中要说明的是备注列,列出来入库或出库的明细并以文本形式体现,如何统计剩余库存并仍以文本的形式备注出剩余库存名字*数量并以+相连接的明细。公式如下:

=LET(h,UNIQUE(B2:B8), #获取不重复的品名

i,DROP(REDUCE("",F2:F8,LAMBDA(x,y,LET( #循环获取逆透视表格

a,TEXTSPLIT(y,"*","+",,,1), #将文本部分拆分成明细表格

b,TAKE(a,,1), #提取明细表名称列

c,--TAKE(a,,-1), #提取明细表数量列并转换成数字方便计算

d,OFFSET(y,,-4), #获取y同一行的品名

e,EXPAND(d,ROWS(a),1,d), #将品名进行拓展行数与明细表行数保持一致

VSTACK(x,IF(OFFSET(y,,-1)="",HSTACK(e,b,c),HSTACK(e,b,-c)))))),1),

#根据是入库还是出库进行判断,如果为空,明细表中的数量变为负数(变量c)。并汇总生成逆透视表。

j,GROUPBY(HSTACK(INDEX(i,,1),INDEX(i,,2)),INDEX(i,,3),SUM,,0), #将明细表转换为聚合表

m,IFS(INDEX(j,,3)=1,INDEX(j,,2),INDEX(j,,3)=0,"",1,INDEX(j,,2)&"*"&INDEX(j,,3)),

#将处理后的聚合表明细部分的名字和数量合并成要求的文本样式

VSTACK(HSTACK(B1,C1,"结存",F1),HSTACK(h,XLOOKUP(h,B2:B8,C2:C8),TAKE(GROUPBY(INDEX(i,,1),INDEX(i,,3)*INDEX(i,,2),SUM,,0),,-1),DROP(REDUCE("",h,LAMBDA(x,y,VSTACK(x,TEXTJOIN("+",1,FILTER(m,TAKE(j,,1)=y))))),1))))

#将名称、单位、库存、备注合并到一张二维表格里。

公式思路:这是我用过最长的公式,之所以长是因为要先将函数还原成明细表,再考虑将明细表计算后按要求合并成最终的结果。公式之所以长是因为要求不规范,需要两次处理备注中的字符串。

逆透视表结果如下:

基布

50

10

基布

40

10

基布

56

1

基布

44

1

浆料

50

20

皮革

40

20

皮革

35

1

皮革

36

1

皮革

37

1

皮革

38

1

皮革

39

1

皮革

15

1

基布

50

-5

基布

40

-8

基布

56

-1

浆料

50

-15

皮革

40

-13

皮革

35

-1

皮革

37

-1

皮革

38

-1

皮革

15

-1

基布

55

10

基布

45

10

基布

56

1

基布

44

1

聚合表的结果如下:

基布

40

2

基布

44

2

基布

45

10

基布

50

5

基布

55

10

基布

56

1

浆料

50

5

皮革

15

0

皮革

35

0

皮革

36

1

皮革

37

0

皮革

38

0

皮革

39

1

皮革

40

7

处理后的聚合表如下:

基布

40

2

基布

44

2

基布

45

10

基布

50

5

基布

55

10

基布

56


浆料

50

5

皮革

36


皮革

39


皮革

40

7

大家看看还有什么更简洁的办法么?

相关推荐

python unittest 基本用法(python pytest)

unittest的使用分为6个步骤:1.导入unittest模块2.定义测试类,父类为unittest.TestCase可继承unittest.TestCase的方法,如setUp和tearDown方...

python中如何利用递归原理找出文件夹中的全部文件

在python中要想查看文件夹中的文件,需要先导入os模块,在python中导入os模块后,定义一个空的列表,用来接收返回的文件,importoslist1=[]接下来,我们定义一个函数,这个函...

Python读取配置文件(config.ini),写入配置文件

一、读取配置文件我的目录如下,在config下有一个config.ini配置文件配置文件内容#定义config分组[config]platformName=AndroidappPackage...

python 文件操作(python文件操作添加下一行)

在Python中,可以使用内置的文件操作函数和方法来进行文件的读取、写入和操作。下面是一些常见的文件操作方法:打开文件:使用open()函数来打开一个文件,并返回一个文件对象。你需要指定文件的路径和打...

失业程序员复习python笔记——excel读写处理

Excel是我们在工作中用到的最频繁的软件之一,它有着强大的计算能力和便捷的图表功能。今天记录一下怎么用python操作excel文件安装excel扩展库如果要用Python操作Excel文...

Python的文件处理(python文件处理方法)

一、文件处理的流程1.打开文件,得到文件句柄并赋值给一个变量2.通过句柄对文件进行操作3.关闭文件示例:d=open('abc')data1=d.read()pri...

Python读写docx文件(python如何读写文件)

Python读写docx文件Python读写word文档有现成的库可以处理pipinstallpython-docx安装一下。https://python-docx.readthedocs.io/...

(简单入门易懂)实例详解:Python csv文件的读写操作

今天为大家带来的内容是:简单入门易懂的是咧详解:Pythoncsv文件的读写操作本文内容主要介绍了Pythoncsv文件的读写操作实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有...

Python3查看文件是否存在,以及读、写与执行的属性

目录技术背景代码实现测试分析总结概要版权声明技术背景在使用python对系统文件进行操作的项目中,经常需要用到对本地文件的存在和读写进行判断的操作。最常用的比如os.exists函数,可以很方便的判断...

Python常用文件操作库使用详解(python中文件操作的例子)

Python生态系统提供了丰富的文件操作库,可以处理各种复杂的文件操作需求。本教程将介绍Python中最常用的文件操作库及其实际应用。一、标准库核心模块1.1os模块-操作系统接口主要功能:文件...

python入门 输入与输出——读和写文件

以下是Python文件读写的入门指南,包含基础操作、安全写法及实用技巧:一、文件操作基础步骤打开文件→读写操作→关闭文件(务必确保最后关闭文件,避免资源泄露)二、文件读取1.基本读取#方法...

第41讲 基本文件操作(和猫妹学Python)

小朋友们好,大朋友们好!我们今天基本文件操作,要学习的内容如下:什么是文件,什么是目录创建和打开文件关闭文件with语句打开文件写入文件内容读取文件什么是文件,什么是目录文件是计算机存储信息的一种形式...

Python自动化办公自学笔记(八)文件操作

一、文件使用在Python里面,文件分为两种类型,一种是文本文件,后缀名为“.txt”,由单一特定编码的字符组成;另一种是二进制文件,由比特0和比特1组成。Python对以上两种文件都有统一的操作步骤...

python 利用python读取DOC文件(python读取word数据)

近期公司需要处理一批DOC文件,而在windows系统中,python没有模块能直接读取doc文件。需要先把doc文件批量转成docx文件,再读取操作。linux系统python有模块可直接读取doc...

Python学不会来打我(83)python读写文件操作总结

python读写文件操作其实是一个很复杂的过程,在python代码中给的内建函数open()、read()、write()等操作起来非常简单,但是这些方法的底层却是很复杂的,这里面涉及到一些操作系统的...