工作中我们经常会碰到一种情况就是,需要对不同工作表名称下的数据进行引用,因为不同工作表名称会有数字、文本等不同的命名方式,所以今天我们来学习一下工作表引用常用的Indirect函数,深入讲解一下这个函数的2种使用方法。
方法1:对数字命名的多工作表数据进行汇总求和
案例:如上图,我们需要汇总表格中用1-6等数字命名的每个人的6个月的销量之和。
函数如下:
SUM(SUMIF(INDIRECT(ROW($1:$6)&"!A:A"),A2,INDIRECT(ROW($1:$6)&"!g:g")))
函数解析:
1、因为每个细分的工作表,每个人对于的位置都不一样,每个月的人数也不一样;首页这个过程中我们需要用sumif条件求和函数来进行计算;
2、在1-6等6个表格数据进行条件判断的时候,需要用到indirect函数引用6张表格的条件区域和数据区域;
INDIRECT(ROW($1:$6)&"!A:A"):代表找出6张表格中的姓名列;
INDIRECT(ROW($1:$6)&"!g:g"):代表找出6张表格中所在的数据列;
3、引用数据作为并进行条件求和后,最后需要用到sum函数进行再次求和。因为sumif函数到这里只是找出了1-6每张表格中,你需要查找的人的数据。所以还需要再次求和。
4、在这里ROW($1:$6)下标代表多个工作表的名称。
方法:对文本内容命名的多工作表数据进行汇总求和
案例:与用法1不同,这次工作表名称是用1月-6月等文本内容进行命名的。同样对引用多个工作表数据的时候,indirect函数使用上面会有些不同。
函数如下:
SUM(SUMIF(INDIRECT((ROW($1:$6)&"月")&"!A:A"),A2,INDIRECT((ROW($1:$6)&"月")&"!g:g")))
函数解析:
1、用法其实跟上面的方方法1的操作是一样的;
2、主要的区别在于引用表格名称的时候,这里变为了:
INDIRECT((ROW($1:$6)&"月")&"!A:A")
因为这里会出现文本内容,所以在这里需要对文本的数据用&进行连接,同时文本内容需要用双引号进行框住。
现在你学会如何使用indirect函数进行多工作表数据引用了吗?