多维表父记录还能这样玩

最近多维表出了父记录,很多群友都不知道有什么用?或者是怎么用?

本文介绍一下父记录的玩法:

使用本表的公式如遇到问题或者发现任何BUG,欢迎与我(wx:leeaqua)联系。

父智能编号

📌

IF(ISBLANK([@父记录]),COUNTIFS([编号],"<="&[@编号],[父记录],"")&"",[@父记录]&"."&COUNTIFS([编号],"<="&[@编号],[父记录],[@父记录]))

说明:公式中&""的作用是为了让countifs的值由数字转为文本

父智能编号2

📌

IF(ISBLANK([@父记录])," "&COUNTIFS([编号],"<="&[@编号],[父记录],""),[@父记录]&"."&COUNTIFS([编号],"<="&[@编号],[父记录],[@父记录]))

说明:表面上看上面两个公式的结果是一样的,实际上第二个公式的前方多了一个" ",这样写的目的是为了之后查找引用树的时候,能够排除干扰项,比如如果存在1.1.1和2.1.1,在查找1.1的时候会把这两个都匹配到,因此如果是: 1.1.1 2.1.1的话,在查找 1.1的时候,就不会匹配 2.1.1了。

分级父编号

📌

IF(ISBLANK([@父记录]),1,1--TRIM([@父记录]))

分级父编号2

📌

IF(ISBLANK([@父记录]),1&"级",1--SUBSTITUTE([@父记录],"级",)&"级")

分级父编号3

📌

SWITCH([@父记录],,"1️⃣","1️⃣","2️⃣","2️⃣","3️⃣","3️⃣","4️⃣","4️⃣","5️⃣","5️⃣","6️⃣")

颜色父编号

📌

SWITCH([@父记录],,"🔴","🔴","🟠","🟠","🟡","🟡","🟢","🟢","🔵","🔵","🟣")

IF(ISBLANK([@父记录]),"🔴",IF([@父记录]="🔴","🟠",IF([@父记录]="🟠","🟡",IF([@父记录]="🟡","🟢",IF([@父记录]="🟢","🔵",IF([@父记录]="🔵","🟣"))))))

IFS(ISBLANK([@父记录]),"🔴",[@父记录]="🔴","🟠",[@父记录]="🟠","🟡",[@父记录]="🟡","🟢",[@父记录]="🟢","🔵",[@父记录]="🔵","🟣")

颜色父编号2

📌

SWITCH([@父记录],,"","","","","","","","","","","")

颜色父编号3

📌

SWITCH([@父记录],,"","","","","","","","","","","")

筒子父编号

📌

SWITCH([@父记录],,"🀙","🀙","🀚","🀚","🀛","🀛","🀜","🀜","🀝","🀝","🀞")

IF(ISBLANK([@父记录]),"🀙",IF([@父记录]="🀙","🀚",IF([@父记录]="🀚","🀛",IF([@父记录]="🀛","🀜",IF([@父记录]="🀜","🀝",IF([@父记录]="🀝","🀞"))))))

IFS(ISBLANK([@父记录]),"🀙",[@父记录]="🀙","🀚",[@父记录]="🀚","🀛",[@父记录]="🀛","🀜",[@父记录]="🀜","🀝",[@父记录]="🀝","🀞")

复制编号

📌

IF(ISBLANK([@父记录]),COUNTIFS([编号],"<="&[@编号],[父记录],"")&"",[@父记录])

同组编号

📌

同级编号:

IF(ISBLANK([@名称]),"",IF(ISBLANK([@父记录]),COUNTIFS([编号],"<="&[@编号],[父记录],"")&"",XLOOKUP([@父记录],[名称],[辅助])))

辅助:

IF(ISBLANK([@名称]),"",IF(ISBLANK([@父记录]),[@同组编号],XLOOKUP([@父记录],[名称],[同组编号])))

说明:这里的公式利用了一个循环机制,两个公式字段相互引用。

父子树

📌

上级编号:

IF(ISBLANK([@父记录]),"",XLOOKUP([@父记录],[名称],[树编号],""))

树编号:

IF(ISBLANK([@父记录]),IF(ISBLANK([@父记录])," "&COUNTIFS([编号],"<="&[@编号],[父记录],""),COUNTIFS([编号],"<="&[@编号],[父记录],[@父记录]))&".",[@上级编号]&IF(ISBLANK([@父记录]),COUNTIFS([编号],"<="&[@编号],[父记录],""),COUNTIFS([编号],"<="&[@编号],[父记录],[@父记录]))&".")

级别:

TEXT(LEN([@树编号])-LEN(SUBSTITUTE([@树编号],".",)),"[dbnum1]")&"级"

上级地址:

IF(ISBLANK([@父记录]),"",XLOOKUP([@父记录],[名称],[组合名称],""))

组合名称:

IF(ISBLANK([@父记录]),[@名称],[@上级地址]&[@名称])

父子记账表

📌

上级编号:

IF(ISBLANK([@父记录]),"",XLOOKUP([@父记录],[名称],[树编号],""))

树编号:

IF(ISBLANK([@父记录]),IF(ISBLANK([@父记录])," "&COUNTIFS([编号],"<="&[@编号],[父记录],""),COUNTIFS([编号],"<="&[@编号],[父记录],[@父记录]))&".",[@上级编号]&IF(ISBLANK([@父记录]),COUNTIFS([编号],"<="&[@编号],[父记录],""),COUNTIFS([编号],"<="&[@编号],[父记录],[@父记录]))&".")

合计:

SUM([@金额],[@下级小计])

下级小计:

SUM(FILTER([金额],IFERROR(FIND([@子编号],[父编号]),0),0))

欠款合计:

SUM(FILTER([金额],IFERROR(FIND([@子编号],[父编号]),0)*([金额]<=0),0))

回款合计:

SUM(FILTER([金额],IFERROR(FIND([@子编号],[父编号]),0)*([金额]>0),0))

本文案例:

父记录还能这么玩https://kdocs.cn/l/cgryU5KLbi4I

在使用多维表的过程中,如遇到公式问题、关联引用问题,欢迎与本人一起交流。

感谢各位提供使用需求及解决思路的群友,以下是部分多维表使用技巧和案例,欢迎有需要的网友学习交流。

多维表函数列表https://kdocs.cn/l/cryI4BWCOzis

多维表公式案例共享表https://kdocs.cn/l/caIDYoTiwjh9

秒懂智能编号https://kdocs.cn/l/csywN1I7IoGB

多维表字符串提取https://kdocs.cn/l/cn7wbyGrYo1N

多维表TEXT函数技巧https://kdocs.cn/l/cmEIOU8rjJ43

emoji表情https://kdocs.cn/l/cuUbJRWe8UuA

易经学习工具https://kdocs.cn/l/cowtbtZdKBLW

父子级联树https://kdocs.cn/l/cvt7gu4IJOY3

广东省
浏览 396
4
8
分享
8 +1
5
4 +1
全部评论 5
 
Kevin Yu
有点不明白,返回的都是fales, 子编号中,没有含父编号, 这个逻辑时怎么样的?能解释一下吗?
· 广东省
回复
AQUA
如果是同一行中,的确不存在子编号包含父编号的情况,但是注意,这里的父编号是代表列,即比如甲送货对应的子编号1.1,可以查找到甲送货1、甲送货2、甲送货3的父编号1.1,再对应这3条数据求和,就得到想要的下级的求和。
· 广东省
回复
 
Kevin Yu
@父记录 和树编号,是什么字段?怎么没有?
· 广东省
回复
 
赵二
学习了。
· 辽宁省
回复
 
WPS 冲浪队长
WPS 冲浪队长

社区管理员

非常详细~ 欢迎多多分享
· 广东省
1
回复