首页 >>  正文

excel公式下拉不生效

来源:baiyundou.net   日期:2024-09-21

作者:bluebird118

       Excel中有一个几乎“万能”的函数组合,她就是Index+small+if+row组合,也称为“万金油的组合公式”。在日常工作中的应用非常广泛,今天我们就来了解这个万金油公式。

       很多朋友在Excel中用公式做查询的时候,都必然会遇到的一个麻烦问题:那就是一对多的查找问题。

       大多数朋友做查询都是从vlookup、index-match组合入门的,然而遇到一对多查询的时候,如果不加辅助列,往往会束手无策,今天我们要讨论的Index+small+if+row组合,就是专门解决一对多查询的一个通用公式。

       如果你能完全掌握这个思路的话,不夸张的说,在Excel中基本上就没有什么查询可以难住你了 。好了,言归正传,先看一个效果图,到底一对多查询是怎样的:

其中的公式是:=IFERROR(INDEX($A$1:$C$15,SMALL(IF($A$1:$A$15=$E$2,ROW($B$1:$B$15),10^3),ROW(B1)),COLUMN(B1)),"")

       不过要想彻底理解这个公式,还得有一些储备知识,例如简单的数组应用,index、small、if和row这几个函数的基本用法也是要了解的。在之前的文章中,index、if、row函数都有介绍过。在这里也提一下:

      首先,来看下index函数,这个函数基本功能是给出一个区域,然后根据对应的行列位置返回查找结果,index一共需要三个参数,第一个参数是数据范围,刚才说了,第三个参数是要查找的内容位于这个范围的第几列,本例中因为要对应查找三列数据,并且列的位置是对应的,所以用了column函数,如下图所示:三个红色的框,第一个是数据范围,第二个是第几行,第三个是第几列。

      其中最难理解的就是第2个参数。接下来我们来展开第2个参数。这个参数的作用是要查找的内容位于数据区域的第几行,如果是一对一的查找,我们可以指定行号或者用match函数来取得行号,但这里是一对多,例如部门是蜀汉的,分别对应了五个行号,如下图所示:

         重要提醒:对这五行数据在表格中的行号我特别标注出来了,分别是2、3、11、12和15,但请注意一点,如果index第一参数所给到的区域并不是从第一行开始的,那么得根据第一参数的区域内的行数。假如第一个参数是从第2行开始的话,那么对应的行数将减去1,分别是1、2、10、11、14。

          实际上,这五个数据在index给到的范围中,分别位于第2、3、11、12和15行,也就是我们希望得到的结果。

对于蜀汉

第一次出现时应该是index(数据范围,2,列位置);

第二次出现时应该是index(数据范围,3,列位置);

第三次出现时应该是index(数据范围,11,列位置);

第四次出现时应该是index(数据范围,12,列位置);

第五次出现时应该是index(数据范围,15,列位置);

。。。。。。

从上面来看,其中发生改变的就是第2个参数,行数在发生变化。

这就是一对多的核心,请务必理解。

       为了将这一想法变成结果,就出来了small+if+row,而这三个函数的组合实际上才是真正的万金油!

       接下来我们来看small函数

        其函数结构是SMALL(array,k),k 为返回的数据在数组或数据区域里的位置(从小到大),array查找的数据区域。也就是第k个最小的位置

        Small函数的作用是在给出的一组数据中挑出指定的第几个最小值,第一个参数是一组数字,第二个参数是一个数字。来我们来看下面这个动图

      图中有9个数,分别是1,2个2,  2个3,2个5,6、8.

      如果公式是=SMALL(A$1:A$9,1),则返回第一个最小值1

      如果公式是=SMALL(A$1:A$9,2),则返回第二个最小值2

      如果公式是=SMALL(A$1:A$9,3),则返回第三个最小值2

      如果公式是=SMALL(A$1:A$9,4),则返回第四个最小值3

      如果公式是=SMALL(A$1:A$9,5),则返回第五个最小值3

     如果公式是=SMALL(A$1:A$9,6),则返回第六个最小值5

     这也是上图中显示的结果。

      注意,这里的第二参数我们是手动输入的,因为把第一个公式下拉的话,第二参数1是不会变的,如果需要第二参数会自己变,就需要借助ROW函数!(row出现)看下图

     这是一个公式下拉的结果,好像是对A列进行了排序一样的效果,有点意思吧~~~

     说完row函数后。我们整体来看下这个公式中

      我们想要的是2、3、11、12和15行,要通过small得到这几个数字,有个思路就是:

部门是蜀汉的,按对应的行号标注;

      不是蜀汉的,都看作比数据中最大的行数要大的数(这个数其实是行号,因为一共15个数)。

而要实现这个目的,只能通过if实现。

(IF($A$1:$A$15=$E$2,ROW($B$1:$B$15),10^3),之前的公众号文章中也有介绍IF函数的,if函数的基本逻辑,想必大家也比较清楚,标黄色部分的意思是给定的区域数据,是否等于E2的值,如果是的话,将返回 ROW($B$1:$B$15),否则就返回10^3(这个数只要比数据的行数大即可,为了不超过数据区域最大的行数,这里往往是写的比较大的数据)

我们来看看IF($A$1:$A$15=$E$2,ROW($B$1:$B$15),10^3)这一段的运算结果吧:

     从上图中,你注意到2、3、11、、12和15了吗?

     到这里,small函数的这部分是不是明白了,也就是index函数的第2个参数。

     如果明白了,我们接着来看。将small函数代入到index函数中,就是我们看到的公式=INDEX($A$1:$C$15,SMALL(IF($A$1:$A$15=$E$2,ROW($B$1:$B$15),10^3),ROW(B1)),COLUMN(B1))

","force_purephv":"0","gnid":"926daa0787cf7bd87","img_data":[{"flag":2,"img":[{"desc":"","height":"500","s_url":"https://p0.ssl.img.360kuai.com/t015dd80a00627586b1_1.gif","title":"","url":"https://p0.ssl.img.360kuai.com/t015dd80a00627586b1.gif","width":"730"},{"desc":"","height":"245","title":"","url":"https://p0.ssl.img.360kuai.com/t01fb7ab98f6b7148e1.jpg","width":"600"},{"desc":"","height":"326","title":"","url":"https://p0.ssl.img.360kuai.com/t019868e7b2be1db895.jpg","width":"554"},{"desc":"","height":"392","s_url":"https://p0.ssl.img.360kuai.com/t0156283e000c18c9b5_1.gif","title":"","url":"https://p0.ssl.img.360kuai.com/t0156283e000c18c9b5.gif","width":"597"},{"desc":"","height":"392","s_url":"https://p0.ssl.img.360kuai.com/t011f42d758b419ec75_1.gif","title":"","url":"https://p0.ssl.img.360kuai.com/t011f42d758b419ec75.gif","width":"597"},{"desc":"","height":"465","s_url":"https://p0.ssl.img.360kuai.com/t01043fee522baf4dc2_1.gif","title":"","url":"https://p0.ssl.img.360kuai.com/t01043fee522baf4dc2.gif","width":"955"}]}],"original":0,"pat":"art_src_1,fts0,sts0","powerby":"hbase","pub_time":1676106538000,"pure":"","rawurl":"http://zm.news.so.com/2b33d8cd734056be6290fbede0903cca","redirect":0,"rptid":"a7d0520163259336","s":"t","src":"什么值得买","tag":[{"clk":"kcareer_1:excel","k":"excel","u":""}],"title":"EXCEL技巧:万金油公式

凌萱波4487为什么我的excel表格计算不能下拉填充? -
池蓝洁15363995364 ______ 点“工具”——“选项”——“重新计算”——勾选“自动重算”,如图: ——“确定”即可.

凌萱波4487excel表格公式下拉怎么不行 而且也是自动重算啊 哪位大神帮我解决下啊 谢谢啦 -
池蓝洁15363995364 ______ =D5*F$3 下拉就可以了.$ 符号是固定的作用,放到行标前就固定行,列则固定列.

凌萱波4487请问在使用EXCEL表格里,出现了version1,公式不能再继续下拉,怎么解决? -
池蓝洁15363995364 ______ 这个我以前似乎遇到过,可是,忘记了.不过我觉得应该与绝对引用有关吧!能够一直拉下来的数值是相对引用, 在excel 工具栏中 重新计算栏中 有自动重算 和手工重算!可能,你的表格中 在手工重算中有标示,那么 你就要在自动重算中打钩!点击确认,看看可以自动重算数值了吗?

凌萱波4487EXCEL无法下拉计算公式 -
池蓝洁15363995364 ______ 工具-选项-重新计算-选自动重算

凌萱波4487excel怎么不能下拉 -
池蓝洁15363995364 ______ excel不能下拉通常可能是设置出现了问题. 工具: excel 方法: 1. 打开excel,点击文件下面的选项 2. 点击高级功能,勾选启动填充柄和单元格拖放功能即 3. 下面看到小黑点出现可以下拉了

凌萱波4487EXCEL2016计算时,下拉无法按照上一个公式计算 -
池蓝洁15363995364 ______ 有黄色图标:设置单元格格式为数值试试 函数下拉无效:文件~选项~公式~勾选自动重算

凌萱波4487我的EXCEL的求和下拉不能用了,请问是哪里出了问题? -
池蓝洁15363995364 ______ 怎么个不能用了?是不是填充柄(小黑点)不见了? 工具-选项-编辑,将“单元格拖放功能”勾上.

凌萱波4487excel重复公式输入完往下拖不显示出来是怎么回事?求高手指点,谢谢! -
池蓝洁15363995364 ______ 这个公式是直接写在单元格里,而不是写在数据有效性里的 即B1单元格写入公式 =IF(COUNTIF(A:A,A1)>1,"重复","") 下拉复制公式

凌萱波4487为什么我的MicrosoftExcel工作表无法拖出计算公式?为?
池蓝洁15363995364 ______ 第一种方法: 在1和2的前面或后面加个标点符号就好了(注意:不要用小数点). 第二种方法:填好1和2后,选取这两个单元格,按右键,会弹出下拉列表对话框,选择“设置单元格格式”,打开,在“数字”下拉框里选“文本”,按“确定”.这样,填好的数字是显示在单元格的左侧(不会在右侧),这样就会拖出来的了. 这两个方法都是都是以“文本”的格式存在的,才会生效.

凌萱波4487Excel公式不能下拉.怎么回事啊·每次都要自己再输一次··· -
池蓝洁15363995364 ______ 应该是你的表格做了部分写保护.

(编辑:自媒体)
关于我们 | 客户服务 | 服务条款 | 联系我们 | 免责声明 | 网站地图 @ 白云都 2024