早教吧作业答案频道 -->其他-->
excel数组公式引用列求值大神们早上好.现有一个数组公式如下:=INDEX(B:B,SMALL(IF((A$1:A$100={"ABC","BCD","CDE"})*(C$1:C$1000),ROW($1:$100),4^8),ROW(A1)))&""然后得到的B列值如下:23423121但是我求B列的和时得到
题目详情
excel 数组公式引用列求值
大神们早上好.
现有一个数组公式如下:
=INDEX(B:B,SMALL(IF((A$1:A$100={"ABC","BCD","CDE"})*(C$1:C$1000),ROW($1:$100),4^8),ROW(A1)))&""
然后得到的B列值如下:
2
3
4
2
3
1
2
1
但是我求B列的和时得到的是空值.公式为=sum(B1:B100)
请问该如何修改呢.
大神们早上好.
现有一个数组公式如下:
=INDEX(B:B,SMALL(IF((A$1:A$100={"ABC","BCD","CDE"})*(C$1:C$1000),ROW($1:$100),4^8),ROW(A1)))&""
然后得到的B列值如下:
2
3
4
2
3
1
2
1
但是我求B列的和时得到的是空值.公式为=sum(B1:B100)
请问该如何修改呢.
▼优质解答
答案和解析
我不看你的话了 我把公式详细的说一遍
首先是数组公式 输入 修改后要按CTRL+SHIFT+回车
第一层 IF(L3="","",.)
就是如果L3是空那公式就显示空 要不就返回后面的公式 就是 下面这个咯
INDIRECT(ADDRESS(SMALL(IF($A$3:$I$32=L3,ROW($A$3:$I$32)),COUNTIF($L$3:L3,L3)),RIGHT(SMALL(IF($A$3:$I$32=L3,ROW($A$3:$I$32)*1000+COLUMN($A$3:$I$32)),COUNTIF($L$3:L3,L3)),3)-1))
indirect 是引用的意思
ADDRESS是返回一个单元格的地址的意思
连起来就是引用ADDRES返回的单元格里面的数据的意思
address分 行 和列 2个参数
SMALL(IF($A$3:$I$32=L3,ROW($A$3:$I$32)),COUNTIF($L$3:L3,L3))是你的行
RIGHT(SMALL(IF($A$3:$I$32=L3,ROW($A$3:$I$32)*1000+COLUMN($A$3:$I$32)),COUNTIF($L$3:L3,L3)),3)-1)
是你的列
如果行等于1 列等于2
那么INDIRECT(DEERESS(1,2))
就是 1 行 2列 就是B2了
好了 现在INDIRECT addres 说好了 主要讲里面的2个参数返回的原理
SMALL(IF($A$3:$I$32=L3,ROW($A$3:$I$32)),COUNTIF($L$3:L3,L3))
意思是 取出IF($A$3:$I$32=L3,ROW($A$3:$I$32))这里面的第COUNTIF($L$3:L3,L3)小的数字
IF($A$3:$I$32=L3,ROW($A$3:$I$32))意思是如果$A$3:$I$32=L3 那么就返回$A$3:$I$32的行号
这里其实可能不止一个相等 所以返回的是一个数组
后面COUNTIF($L$3:L3,L3) 意思是计算$L$3:L3 里面有几个L3 这里是1个 但走你公式看 下拉后$L$3:L3 会变成4 5 6 那么肯定就不是一个了
结合前面的我理解是返回$A$3:$I$32=L3 里面行号最大的那个行号 COUNTIF($L$3:L3,L3)是相同的数量 SMALL符合条件里面第“ 相同数量” 最小的一个
假设4个相同 那返回第4小的 那么就是最大的咯
下面是列
RIGHT(SMALL(IF($A$3:$I$32=L3,ROW($A$3:$I$32)*1000+COLUMN($A$3:$I$32)),COUNTIF($L$3:L3,L3)),3)-1)
里面SMALL(IF($A$3:$I$32=L3,ROW($A$3:$I$32)*1000+COLUMN($A$3:$I$32)),COUNTIF($L$3:L3,L3))类似上面的解释你应该可以理解
RIGHT意思是取最右面3个
最后减 1 是最外层的 就是RIGHT后减1
不知理解否?
首先是数组公式 输入 修改后要按CTRL+SHIFT+回车
第一层 IF(L3="","",.)
就是如果L3是空那公式就显示空 要不就返回后面的公式 就是 下面这个咯
INDIRECT(ADDRESS(SMALL(IF($A$3:$I$32=L3,ROW($A$3:$I$32)),COUNTIF($L$3:L3,L3)),RIGHT(SMALL(IF($A$3:$I$32=L3,ROW($A$3:$I$32)*1000+COLUMN($A$3:$I$32)),COUNTIF($L$3:L3,L3)),3)-1))
indirect 是引用的意思
ADDRESS是返回一个单元格的地址的意思
连起来就是引用ADDRES返回的单元格里面的数据的意思
address分 行 和列 2个参数
SMALL(IF($A$3:$I$32=L3,ROW($A$3:$I$32)),COUNTIF($L$3:L3,L3))是你的行
RIGHT(SMALL(IF($A$3:$I$32=L3,ROW($A$3:$I$32)*1000+COLUMN($A$3:$I$32)),COUNTIF($L$3:L3,L3)),3)-1)
是你的列
如果行等于1 列等于2
那么INDIRECT(DEERESS(1,2))
就是 1 行 2列 就是B2了
好了 现在INDIRECT addres 说好了 主要讲里面的2个参数返回的原理
SMALL(IF($A$3:$I$32=L3,ROW($A$3:$I$32)),COUNTIF($L$3:L3,L3))
意思是 取出IF($A$3:$I$32=L3,ROW($A$3:$I$32))这里面的第COUNTIF($L$3:L3,L3)小的数字
IF($A$3:$I$32=L3,ROW($A$3:$I$32))意思是如果$A$3:$I$32=L3 那么就返回$A$3:$I$32的行号
这里其实可能不止一个相等 所以返回的是一个数组
后面COUNTIF($L$3:L3,L3) 意思是计算$L$3:L3 里面有几个L3 这里是1个 但走你公式看 下拉后$L$3:L3 会变成4 5 6 那么肯定就不是一个了
结合前面的我理解是返回$A$3:$I$32=L3 里面行号最大的那个行号 COUNTIF($L$3:L3,L3)是相同的数量 SMALL符合条件里面第“ 相同数量” 最小的一个
假设4个相同 那返回第4小的 那么就是最大的咯
下面是列
RIGHT(SMALL(IF($A$3:$I$32=L3,ROW($A$3:$I$32)*1000+COLUMN($A$3:$I$32)),COUNTIF($L$3:L3,L3)),3)-1)
里面SMALL(IF($A$3:$I$32=L3,ROW($A$3:$I$32)*1000+COLUMN($A$3:$I$32)),COUNTIF($L$3:L3,L3))类似上面的解释你应该可以理解
RIGHT意思是取最右面3个
最后减 1 是最外层的 就是RIGHT后减1
不知理解否?
看了 excel数组公式引用列求值...的网友还看了以下:
5×0.7=0.43×5=3.6÷0.9-4=240÷37≈3.6-0.36=8.1-2.2=0. 2020-04-07 …
已知关于X的一元二次方程x^2+2(k-1)x+k^2-1=0有两个不相等的实数根已知关于x的一元 2020-05-16 …
6.脱式计算(1)2/13除15/26乘5/8(2)2/3除5/8加1/3除5/8(3)(13/2 2020-06-20 …
1()然成风2()然自在3()然无味4()然而至5()然而去6()然作色7()然可怖8()然自若9 2020-06-22 …
已知2=2,2+5=7=1/2*(2+5)*2,2+5+8=15=1/2*(2+8)*3,2+5+ 2020-07-19 …
0.32.5-1.801-0.7+0.8-2.2中既大于2,有小于2的是?急0.32.5-1.80 2020-07-20 …
必修I·指数函数部分化简[1+2^(1/8)][1+2^(1/4)][1+2^(1/2)]快+好者 2020-08-02 …
(x-2)^2=9(x+3)(步骤)用十字相乘法:x^2-5倍的根号2*x+83x^2-2x-1= 2020-08-03 …
直接写出得数9+7.8-3.8=5÷2×0.8=0.7+0.4×1.5=2.4-2.4÷1.2=0. 2020-11-19 …
图表,自然数以一定的规律排列.横的记位行,竖的记为列,如8在第2行第3列,记为8=(2,3),12在 2020-11-29 …