首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Excel公式技巧25: 使SUMIFSCOUNTIFS函数内的间接列引用变化

使用Excel朋友都知道,将包含相对列引用的公式复制到其他列时,这些引用也会相应地更新。...因此,我们有一个相对简单的方法,可以从连续的列中获得条件和。 但是,如果我们希望增加的单元格区域是间接引用的,那该怎么办?...B:B"),"Y") 其中,A1包含要引用的工作表名称(例如“Sheet1”)。 当我们向右拖动此公式时,间接引用的单元格区域不会改变。...现在的问题是:我们如何修改第一个公式,以便将其向右复制后,依次获得以下等价的公式: =SUMIFS(INDIRECT("'"&$A$1&"'!D:D"),INDIRECT("'"&$A$1&"'!...A:A 而偏移的列数等于: COLUMNS($A:B) 即2,于是传递到OFFSET函数后得到: Sheet2!C:C 然而,如果间接引用的不是一个工作表,而是多个工作表,如何处理?

2.8K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Excel公式技巧106:将表数据转换成列数据

    这是最近一位网友问我的问题。如下图1所示,需要使用公式将单元格区域A1:D4中的数据转换成单元格区域G1:H10中的数据。...图1 刚开始看到这个问题,考虑得复杂了些,我想使用一个公式来做到,但没能实现,使用两个公式可以轻松完成。 这是一个典型的循环取数示例。...对于列G来说,每3次获取同一个数据;对于列H来说,每3次获取同一行中3个单元格中的数据。...这样,使用: INT((ROWS(H$1:H1)-1)/3)+1 将公式向下拖拉复制的话,随着行数的增加,将依次获取: 1,1,1,2,2,2,3,3,3 使用: MOD((ROWS(H$1:H1)-1...),3)+1 将公式向下拖拉复制的话,随着行数的增加,将依次获取: 1,2,3,1,2,3,1,2,3 将其作为INDEX函数的参数,即可获取相应单元格中的值。

    1.8K20

    Excel公式技巧24: Excel公式中的降维技术

    进一步,使用公式: =MID(A1,{1,2},{1;2;3}) 可以得到一个3行2列数组: {"A","m";"Am","ma";"Ama","map"} 公式中两个参数值的数组彼此正交,MID函数的参数...这样,Excel返回#N/A作为结果数组中的第三个元素。 实际上,Excel为了解决传递两个大小不同的数组的问题,重新定义了两个中较小的一个,使其匹配较大的数组。...;"M","o",#N/A;"A","i",#N/A;"A","i",#N/A} 可参考《Excel公式技巧06: COUNTIFS函数如何处理以数组方式提供的条件》中讲解的对数组的解析的内容。...显然,这里的数据是二维的,是一个10行5列的数组,其Excel表示为: {"A1","B1","C1","D1","E1";"A2","B2","C2","D2","E2";"A3","B3","C3"...根据其定义,列向量当然是一维的。这里使用的技术请参阅《Excel公式技巧03:INDEX函数,给公式提供数组》、《Excel公式练习44:从多列中返回唯一且按字母顺序排列的列表》。

    2K22

    Excel公式练习:求三列数值之和等于指定值的组合数

    在练习的过程中,认真思考,不断尝试,以此来磨练自己的公式与函数应用技能,也让研究Excel的大脑时刻保持着良好的状态。...同时,想想自己怎么解决这个问题,看看别人又是怎样解决的,从而快速提高Excel公式应用水平。 Q:有3列数据,每列有10个数值,从每列中取1个数值,这3个数值相加的和为20,有多少种组合。...图1 要求编写一个公式,返回其组合数。 规则:列A中的数值只能使用1次,其他两列数值可任意使用。 写下你的公式。 A:确实很具有挑战性。 公式1:数组公式。...(C2:C11) 会得到由列B中的数值与列C中的数值相加的所有结果。...注意,公式通过将N函数生成的1/0数组与ROW函数生成的垂直数组相乘,巧妙地将每行中有多个20的结果转换成了1个,从而满足列A中的数值只能出现1次的要求。 公式2:数组公式。

    1.5K50

    Excel公式技巧73:获取一列中长度最大的数据值

    在《Excel公式技巧72:获取一列中单元格内容的最大长度》中,我们使用一个简单的数组公式: =MAX(LEN(B3:B12)) 获取一列中单元格内容最长的文本长度值。...那么,这个最长的文本是什么呢?我们如何使用公式获取长度最长的文本数据值?有了前面的基础后,这不难实现。...仍以上文示例工作表为例,可以使用数组公式: =INDEX(B3:B12,MATCH(MAX(LEN(B3:B12)),LEN(B3:B12),0)) 结果如下图1所示。 ?...图1 我们已经知道,公式中的: MAX(LEN(B3:B12)) 得到单元格区域中最长单元格的长度值:12 公式中的: LEN(B3:B12) 生成由单元格区域中各单元格长度值组成的数组: {7;6;4...“数据”,则公式如下图2所示。

    6.3K10

    Excel实战技巧110:快速整理一列数据拆分成多列(使用公式)

    在《Excel实战技巧109:快速整理一列数据拆分成多列》中,我们使用一种巧妙的思路解决了将一列数据拆分成多列的问题。本文介绍使用公式实现的方法。 示例工作簿中的数据如下图1所示。...公式中: A3:A29,是列A中原数据列表。 ROWS(E4:E4),统计指定区域的行数,区域通过锁定第一个引用并保留第二个引用为相对引用来扩展。...当公式向下拉时,行数将增加(1,然后是 2,3,等等……)。 COUNTA(E3:G3),得到单元格区域E3:G3中非空单元格数,本例中是3。 COLUMNS(E3:E3),统计指定区域的列数。...当公式向右拉时,列数将增加(1,然后是 2,3,等等……)。...+(2)*(0)+0) =INDEX(A3:A29,1) 得到单元格A3中的值: 商品1 你可以照此思路,分析一下单元格E5或者F4中的公式,进一步熟悉这个公式。

    3.9K20

    excel 同时冻结首列和首行_word怎么一列求平均值

    大家好,又见面了,我是你们的朋友全栈君。   之前ytkah只知道excel可以冻结首行或首列,但还不清楚如何同时冻结excel首行和首列,后面看到小C的报表,问了他才明白怎么操作。   ...首先,我们先把选中B2单元格,点击导航菜单的“视图” – “冻结窗格” – “冻结拆分窗格”   那如果想冻结前两行前三列可以吗?答案是可以的,选中D3,再点击冻结拆分窗格。...“D”代表列的序列号,以字母形式表示,“3”代表行序列号,用数字表示,想冻结几行几列就选中行、列序号加1的单元格,再冻结就可以了 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn

    1.2K30

    Excel公式技巧87:使用FREQUENCY()求非连续区域上的条件平均值

    图1 对于每个人,电话呼叫数量拆分成两类:ACD和AMS,我们需要从数据集中得到ACD的平均数,并且统计的平均值不应考虑0值所在的单元格,因此正确的答案应该是56: (24+21+99+67+87+6+...通常,我们可以使用AVERAGEIF函数来执行此操作,但由于ACD数据位于三个单独的或不连续的单元格区域内,因此我们无法利用此函数执行此操作。此公式将返回#VALUE!...错误,因为AVERAGEIF函数无法处理非连续区域: =AVERAGEIF((B3:B7,D3:D7,F3:F7),"0") 要获取不连续的区域的平均值,我们通常可以使用SUM/COUNT函数,如下所示...公式中: SUM(B3:B7,D3:D7,F3:F7) 很好理解,求这三个区域的数值之和。...因此,公式等价于: =392/{7} 结果: 56 如果有空单元格,或者即使非连续区域的大小不同,该公式仍然适用。

    2.1K20

    Excel公式技巧:获取最后5个数值中3个数的平均值

    最近,使用工作表记录了员工日常的表现,表现是用分数来评估的。然而,记录并不连续,并且每位员工记录的次数又会有不同,如下图1所示。 图1 我想得到每位员工最后5次得分中,去除最高分和最低分后的平均值。...当然,如果该名员工得分次数不足5次,则取平均值。 首先,我们需要确定最后的5位数值。...但是,每位员工得分的次数不一样,且输入也不一定是连续的,例如代号A的员工最后5位数值位于B2:F2,而代号B的员工最后5位数值位于K3:Q3,一个起始于第2列,一个起始于第11列,如何获取这个起始位置是关键...,FALSE,FALSE,FALSE,FALSE,FALSE,FALSE,FALSE,FALSE,FALSE,FALSE,FALSE,FALSE,FALSE,FALSE} 这样,就会提取出所有含有数值的列的列号...以上,就是公式的核心部分。理解了这部分,后面就好办了。 求该区域的数值之和,然后减去其中的最大值和最小值,除以3,就是平均值了。

    1K30

    Excel公式技巧107:将表数据转换成列数据(续)

    在《Excel公式技巧106:将表数据转换成列数据》中,详细解析了一位网友问我的问题的解答过程。然而,事情并没有完。上次提供的示例数据太完美了,所以实现起来相对简单。...图1 图2 由于在单元格区域B2:E6中每行的数据不一,这给编写公式带来了难度。...我的思路是,对于工作表Sheet1中列A的数据,根据同一行在单元格区域B2:E6中数据的数量,计算出共有多少个数据要重复,如下图3所示,这是一个二维数组。...图3 然后,利用降维技术(该技术详见《Excel公式技巧24:Excel公式中的降维技术》),将这个二维数组变成一维数组,公式如下: =INDEX(IF((B2:E6""),A2:A6,""),N(...其实,公式里面有很多部分都是重复的,我们可以使用名称来将公式进行简化。 单击功能区“公式”选项卡中的“定义名称”来创建名称。 名称:Pos 引用位置:=Sheet1!

    1.6K10

    Excel公式技巧:Excel公式中的数字9.99999999E+307

    这个数字:9.9999999E+307,我们经常会在公式中用得上它。这是一个神奇的数字,在查找数值时能够发挥很大的作用。本文介绍的就是这个数字的使用技巧。...9.9999999E+307是Excel能够识别的最大数字,它通常与LOOKUP函数或MATCH函数结合使用,以查找列/行中的最后一个数字条目,或分别查找行/列中数值的最后一行行号/列号。...在本示例中,LOOKUP函数查找最后一个小于或等于查找值9.9999999E+307的条目,类似的规则或MATCH函数返回行号。...因此,要查找列中的最后一个数字条目,可以使用: =LOOKUP(9.9999999E+307,A:A) 或者从行中返回最后一个数字条目: =LOOKUP(9.9999999E+307,1:1) 类似地,...要获取数字条目的最后一行,使用公式: =MATCH(9.99999E+307,A:A) 或者,对于行,使用公式: =MATCH(9.99999E+307,1:1) 有兴趣的朋友,可以仔细研究,在需要时可以将此技术进行灵活运用

    1K30

    按照A列进行分组并计算出B列每个分组的平均值,然后对B列内的每个元素减去分组平均值

    一、前言 前几天在Python星耀交流群有个叫【在下不才】的粉丝问了一个Pandas的问题,按照A列进行分组并计算出B列每个分组的平均值,然后对B列内的每个元素减去分组平均值,这里拿出来给大家分享下,一起学习..."num"列每个分组的平均值,然后"num"列内的每个元素减去分组平均值 df["juncha"] = df.groupby("lv")["num"].transform(demean) print(df...(输入是num列,输出也是一列),代码如下: import pandas as pd lv = [1, 2, 2, 3, 3, 4, 2, 3, 3, 3, 3] num = [122, 111, 222...df.groupby('lv')["num"].transform('mean') df["juncha"] = df["num"] - df["gp_mean"] print(df) # 直接输出结果,省略分组平均值列...这篇文章主要分享了Pandas处理相关知识,基于粉丝提出的按照A列进行分组并计算出B列每个分组的平均值,然后对B列内的每个元素减去分组平均值的问题,给出了3个行之有效的方法,帮助粉丝顺利解决了问题。

    3K20

    Excel公式技巧21: 统计至少在一列中满足条件的行数

    在这篇文章中,探讨一种计算在至少一列中满足规定条件的行数的解决方案,示例工作表如下图1所示,其中详细列出了各个国家在不同年份废镍的出口水平。 ?...转换成Excel公式为: =COUNTIFS(B2:B14,">=1000",C2:C14,">=1000")+COUNTIFS(B2:B14,">=1000",C2:C14,"的结果涉及的列数不只是两列,甚至可能是多列的情况。例如,假设要确定从2004年到2012年每年至少有一个数字大于或等于1000的国家的数量。...然而,公式显得太笨拙了,如果考虑的列数不是9而是30,那会怎样! 幸运的是,由于示例中列区域是连续的,因此可以在单个表达式中查询整个区域(B2:J14),随后适当地操纵这个结果数组。...并且,由于上述数组(一个13行乘9列的数组)包含9列,因此我们用来形成乘积的矩阵的行数必须等于该数组的列数。

    4.1K10

    Python 读取excel指定的列

    还没有介绍如何读取指定的列。 二、举例 目前有一张水果报价表,内容如下: ? 需要提取品名和成本价,完整代码如下: #!.../usr/bin/env python3 # coding: utf-8 import xlrd # 打开excel文件,创建一个workbook对象,book对象也就是fruits.xlsx文件,表含有...rbook.sheets() # xls默认有3个工作簿,Sheet1,Sheet2,Sheet3 rsheet = rbook.sheet_by_index(0)  # 取第一个工作簿 # 循环工作簿的所有行...for row in rsheet.get_rows():     product_column = row[1]  # 品名所在的列     product_value = product_column.value...= '品名':  # 排除第一行         price_column = row[4]  # 价格所在的列         price_value = price_column.value

    2.4K10

    Excel公式练习38: 求一列中的数字剔除掉另一列中的数字后剩下的数字

    本次的练习是:如下图1所示,在单元格区域A2:A12和B2:B12中给定两列数字,要在列C中从单元格C2开始生成一列数字。规则如下: 1. 列B中的数字的数量要小于等于列A中数字的数量。 2....列B中的任意数字都可以在列A中找到。 3. 在列A或列B已存放数字的单元格之间不能有任何空单元格。 4. 在列C中的数字是从列A中的数字移除列B中的数字在列A中第一次出现的数字后剩下的数字。 5....换句话说,列B和列C中的数字合起来就是列A中的数字。 ? 图1 在单元格D1中的数字等于列A中的数字数量减去列B中的数字数量后的值,也就是列C中数字的数量。...公式的思路就是构造一个数组,能够实现在List1和List2之间执行MATCH函数查找时,列C中的数值就是找不到的值,返回FALSE。 然而,实现起来并不是想像中的那么简单。...在公式中IF子句的第一部分: IF(ROWS($1:1)>$D$1,"" 非常直观,如果公式向下拖放后ROWS函数的值大于7,则返回空。 重点在IF子句的第二部分,即其判断条件为FALSE的部分。

    3.4K20

    Excel公式技巧71:查找一列中有多少个值出现在另一列中

    学习Excel技术,关注微信公众号: excelperfect 有时候,我们想要知道某列中有多少个值同时又出现在另一列中,例如下图1所示,列B中有一系列值,列D中有一系列值,哪些值既出现有列B中又出现在列...因为数据较少,不难看出,在列B中仅有2个值出现在列D中,即“完美Excel”和“Office”。 ?...2 公式中: MATCH(B3:B13,B3:B13,0) 查找单元格区域B3:B13中每个单元格的值在该区域首次出现的位置,得到数组: {1;2;3;1;5;6;2;3;5;1;2} 公式中: ROW...({"完美Excel";"Office";"Excel";"";"excelperfect";"Word";"";"";"";"";""},D3:D16,0) 查找上述不重复值组成的数组在单元格区域D3...传递给COUNT函数统计数组中数字的个数: COUNT({1;5;#N/A;#N/A;#N/A;#N/A;#N/A;#N/A;#N/A;#N/A;#N/A}) 得到结果: 2 即列B中有两个值在列D中出现

    3.3K20
    领券