Execl本身具有很方便的排序与筛选功能,下拉;数据”菜单即可选择排序或筛选对数据清单进行排序或筛选。但也有不足,首先无论排序或筛选都改变 了原清单的原貌,特别是清单的数据从其它工作表链接来而源数据发生变化时,或清单录入新记录时必须从新进行排序或筛选。其次还有局限,例如排序只能最多对 三个关键字(三列数据)排序,筛选对同一列数据可用;与”、或;或”条件筛选,但对不同列数据只能用;与”条件筛选。
例如对某张职工花 名册工作簿,要求筛选出年龄大于25岁且小于50岁或年龄大于50岁或小于25岁都是可行的,如同时要求性别是男的或女的也是可行的。但要求筛选出女的年 龄在22岁到45岁,男的年龄在25岁到50岁时Execl本身具有的筛选功能则无能为力了。再者排序与筛选不能结合使用,即不能在排序时根据条件筛选出 来的记录进行排序。例如有一张职工资料清单,其中有的职工已经退休,对在职职工的年龄进行排序时无法剔除已退休职工的数据。
本文试图用Execl的函数来解决上述问题。
一、用函数实现排序
题目:如 有一张工资表,A2:F501,共6列500行3000个单元格。表头A1为姓名代码(1至500)、B1为姓名、C1为津贴、D1为奖金、E1为工资、 F1收入合计。现要求对职工收入从多到少排序,且在职工总收入相同时再按工资从多到少排序,在职工总收入和工资相同时再按奖金从多到少排序,在职工职工总 收入和工资、奖金相同时再按津贴从多到少排序。
方法:G1单元格填入公式
;=if(F2=0,10^100,INT(CONCATENATE(999-f2,999-e2,999-d2,999-c2)))”,
CONCATENATE 是一个拼合函数,可以把30个以下的单元的数据拼合成一个数据,这些被拼合的数据之间用逗号分开。用f2、e2等被拼合的数据用999来减,是为了使它们 位数相同。(假定任何一个职工的总收入少于899元)。被拼合成的函数是文本函数,CONCATENATE与INT函数套用是为了使文本转换为数字。最外 层的if函数是排序时用来剔除不进行排序的记录,在本例中指收入为零的记录。(在上文提到的职工年龄排序,则公式改为;if(f2="退休", 10^100,.....)”,即剔除了退休职工。)
第二步把G1单元格的公式拖放到G500单元格(最简便的方法是点击G1单元格后向G1单元格右下方移动鼠标,见到黑十时双击鼠标就完成了G1到G500的填充)。
第三步在在H2单元填入公式;=MATCH(SMALL(G:G,ROW(A1)),G:G,0)”与第二步一样拖放到H501单元格。此公式实际上是 把三列公式合成一列公式,ROW(A1)即为A1的行数是1,随着向下拖放依次为2、3、4...,SMALL(G:G,ROW(A1))为 G列中最小的数随着向下拖放依次为第2、第3、..小的数,MATCH(SMALL(G:G,ROW(A1)),G:G,0)即为G列各行的数据中最小、 第2、第3小等的数据在第几行。
第四步把A1至F1单元格的表头复制到I1至N1单元格,在I2单元格输入公式 ;=INDEX($A$2:$F$501,$H2, COLUMN(A$1))”INDEX函数是一个引用函数,即把$A$2:$F$501单元格列阵第$H2行第COLUMN(A$1)列的数据放入I2单 元格。然后把I2单元格的公式拖放到N2单元格,点击N2单元格后向N2单元格右下方移动鼠标见到黑十时双击鼠标就完成了I2到N501单元格的填充到此全部完成。
以上叙述看似繁杂实际非常简单,只要把A1至F1的表头复制到I1至N1单元格,再分别在G1、H2、I2单元格输入公式然后向下拖放,即使对EXCEL应用不熟练的同志一分锺内便能完成。
对上述程序稍作变化还可得到更多用度。上面例子数据是从大到小排列的,如H列的函数中的SMALL改为LARGE,上面例子数据就从小到大排列了。如 H2单元格的公式改为;=IF(O1=1,MATCH(SMALL(G:G,ROW(A1)),G:G,0),MATCH(LARGE(G: G,ROW(A1)),G:G,0))”并把H2单元格的公式向下拖放。这样在O1单元格输入1上面例子数据是从大到小排列的,O1单元格输入1以外的数 上面例子数据就从小到大排列了。
如在H列前插入若干列,如插入一列,则现在的H列输入类似G列的公式,例如 ;=if(F2=0,10^100,d2)”,现在的I列的公式改为 ;=IF(P1=1,MATCH(SMALL(G:G,ROW(A1)),G:G,0),MATCH(SMALL(H:H,ROW(A1)),H:H,0)))” 即在P单元格输入1以外的值就实现了按奖金大小排序.这样只要通过改变P1(原来的O1单元格)单元格内容的改变就能立即得到按不同要求的排序。
安卓Android 6.0无法连接手机的原因: 出现无法连接电脑问题原因......
阅读Excel如何把想要的人筛选出来 Excel筛选数据的操作方法,可以在......
阅读outlook邮箱作为一款功能十分齐全的软件,让用户享受到了不错的......
阅读在使用我们的精品win10系统时,我们日常会需要进行电源的相关......
阅读ai怎么显示定界框呢?如果各位亲们还不了解的话,就来这里学习......
阅读Excel表格是一款非常好用的数据处理软件,在其中我们可以看使用各种图表帮助我们进行数简单分析和比较。在插入图表时我们也可以根据自己的实际需要选择恰当的图表并设置一定的图表样式...
次阅读
在Excel表格中进行数据的编辑和处理是很多小伙伴的办公常态,在Excel表格中我们有时候还会将数据生成各种图表,方便我们进行数据的分析和处理。如果我们在Excel表格中插入折线图后,希望更...
次阅读
在需要编辑和处理数据时,我们通常都会首选Excel表格这款软件,在Excel表格中我们不仅可以收集和存储大量数据,还可以在其中进行各种专业化的数据处理。比如我们可以进行一些基础的加减...
次阅读
excel是一款专门用来制作电子表格的文件,为用户带来了许多的便利和好处,当用户在excel软件中编辑表格文件时,会发现其中的功能是很强大的,用户简单操作几步即可完成表格数据的录入和...
次阅读
Excel表格是一款非常好用的数据软件,很多小伙伴都在使用。如果我们需要在Excel表格中设置输入指定内容后变成特定的样式效果,比如设置输入数字1后自动变为红色等等,小伙伴们知道具体该...
次阅读
很多小伙伴在编辑表格文档的时候都会选择使用Excel程序来进行操作,因为Excel中的功能十分的丰富并且操作简单。在使用Excel的过程中,有的小伙伴可能会遇到输入的数字最后几位变为“0”的...
次阅读
excel软件是用户用来编辑表格文件的办公软件,在这款软件中有着许多实用的功能来解决用户遇到的编辑问题,给用户带来了许多的好处,并且深受用户的喜爱,当用户在使用这款办公软件时,...
次阅读
在Excel表格中进行数据的编辑和处理是很多小伙伴的办公常态,在Excel表格中我们有时候会需要在原数据后面添加统一的单位,比如我们有时候会需要在数据后面统一添加价格单位等等,这种情...
次阅读
excel软件中的功能是很丰富的,满足了用户对表格的编辑需求,当用户在编辑表格时,一般都少不了数据的整理与计算,为了更好的展示数据之间的关系联系,用户直接在表格中插入一些图表直...
次阅读
在Excel表格中有一个“定位条件”功能,使用该功能我们可以快速定位到指定单元格,比如我们可以快速定位到空值单元格,快速定位到最有一个单元格,快速定位到行内容或者列内容差异单元...
次阅读
wps中excel表格怎样算出日期减日期等于天数呢,话说不少用户都在咨询这个问题呢?下面就来小编这里看下wps中excel表格算出日期减日期等于天数的图文操作步骤吧,需要的朋友可以参考下哦。...
次阅读
很多小伙伴在编辑表格文档时都会选择使用Excel程序,因为在Excel程序中我们可以使用各种工具来对表格中的数据进行编辑。当我们想要快速得到一堆数据中排名前几的数据时,我们只需要先打...
次阅读
比较熟悉Excel表格的小伙伴们都知道,在Excel表格中有很多非常好用的函数公式,可以帮助我们进行各种批量操作,进行高效办公。比如我们可以使用sum函数求和,使用sumif进行条件求和,使用...
次阅读
excel软件是用户日常工作中经常使用的一款电子表格制作软件,它为用户提供了强大且实用的功能,让用户可以美化表格、设置单元格格式或是调整表格大小等,总之里面的功能能够很好的满足...
次阅读
excel是一款专业的电子表格制作软件,为用户带来了许多的便利和好处,当用户在excel软件中编辑表格文件时,会发现其中的功能是很强大的,用户不仅可以快速完成数据录入,还可以调整单元...
次阅读