Vlookup求和一个包含逗号分隔值的单元格

时间:2018-11-30 20:00:37

标签: excel excel-formula

我有一个表,其中包含农场田地和每个田地中包含的英亩。这些字段是共同拥有的,并且按百分比分割。

字段拆分表:
Field Splits Table

当前,我为每个字段创建一个新行,并对每个字段中包含的英亩使用sumif,然后使用另一个vlookup计算每个人对每个字段的欠款。

SUMIF($A$3:$A$15,D19,$B$3:$B$15)
VLOOKUP(D19,$A$3:$F$15,4,FALSE)*F19 - to calculate BD Share ($)
VLOOKUP(D19,$A$3:$F$15,6,FALSE)*F19 - to calculate CK Share ($)

发票拆分表:
Invoice Splits Table

我找到了VBA代码,允许用户在下拉列表中选择多个值,这样我就可以选择与特定发票有关的多个字段,并将它们显示在一个单元格中,以逗号分隔。我的问题是我是否可以对引用多个逗号分隔列表中的多个值的vlookup的结果求和以计算适当的发票拆分?

我已经根据“发票分割表”图像中显示的值创建了一个我要达到的目标的模型。这有可能吗?

发票分割计算器示例:
Invoice Splits Calculator Example

1 个答案:

答案 0 :(得分:1)

使用此数组公式:

=SUMPRODUCT(SUMIF($A$3:$A$15,,TRIM(MID(SUBSTITUTE(D19,",",REPT(" ",99)),(ROW($A$1:INDEX($A:$A,LEN(D19)-LEN(SUBSTITUTE(D19,",",""))+1))-1)*99+1,99)),$B$3:$B$15))

作为数组公式,退出编辑模式时需要使用Ctrl-Shift-Enter而不是Enter进行确认。

对于VLOOKUP,只需更改SUMIF中的Sum列:

=SUMPRODUCT(SUMIF($A$3:$A$15,,TRIM(MID(SUBSTITUTE(D19,",",REPT(" ",99)),(ROW($A$1:INDEX($A:$A,LEN(D19)-LEN(SUBSTITUTE(D19,",",""))+1))-1)*99+1,99)),$D$3:$D$15)) * F19

=SUMPRODUCT(SUMIF($A$3:$A$15,,TRIM(MID(SUBSTITUTE(D19,",",REPT(" ",99)),(ROW($A$1:INDEX($A:$A,LEN(D19)-LEN(SUBSTITUTE(D19,",",""))+1))-1)*99+1,99)),$F$3:$F$15)) * F19