用Excel函数实现排序与筛选的方法
发布时间:2023-10-14 08:57:56
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单元格)单元格内容的改变就能立即得到按不同要求的排序。
二、用函数实现筛选
题目
如有一张职工名册表,A2:F501,共6列500行3000个单元格。表头A1为姓名代码(1至500)、B1为姓名、C1为性别、D1为年龄、E1为学历、F1职称。现要求对职工的性别、年龄、学历、职称进行交错筛选,例如要求在同一张表上筛选出1、女的年龄在22岁到45岁,男的年龄在25岁到50岁,2、女博士,3、男博士后。
方法
第一步在G2单元格输入公式”=IF(OR(AND(C2="女",D2>=22,D2<=45),AND(C2="男",
D2>=25,D2<=50)),ROW(A1),0)“,在H2单元格输入公式”=IF(AND(C2="女",E2="博士"),
ROW(B1),0)“,在I2单元格输入公式”=IF(AND(C2="男",E2="博士后"),ROW(B1),0)“。在J2单元格输入公式“=IF(K$2=1,LARGE(G:G,ROW(A1)),IF(K$2=2,LARGE(H:H,ROW(A1)),
IF(K$2=3,LARGE(I:I,ROW(A1)),0)))”然后用上述提到的方法向下拖放。G、H、I列的公式的含义就是凡符合筛选条件的行记录下行号否则为零,J列的公式的含义根据K2的数值选择G、H、I中的一列进行排序并把不合条件的行除去。
第二步在K1单元格输文字”筛选选择”,A1到F1表头复制到L1到Q1,在L2单元格输入
公式“=IF($J2=0,0,INDEX($A$2:$F$501,$J2,COLUMN(A$1)))”,然后向右拖放到Q2,再向下拖放。INDEX函数的含义上文已说明。
第三步在P1单元格输入1或2或3便可实现上述三种筛选。


猜你喜欢
- 如今,U盘已经成为生活和办公中不可缺少的一部分了,体积小,方便携带,而且价格便宜。其实我们可以在win8.1系统中通过一些技巧优化U盘性能,
- 如果重装系统之前电脑的声音是正常的,重装之后却没声音了,那基本是由于声卡驱动故障引起的,只要重新安装一下声卡驱动就能解决。首先从网上下载驱动
- 我们在使用电脑的时候,有的情况下可能会出现显示器出现了无法全屏并且显示有黑边的情况。有的小伙伴可能不知道应该怎么解决这个问题。那么小编觉得我
- ppt表格中插入的图片怎么调整格式?ppt表格中插入了图片作为底纹,想要设置图片的样式,该怎么设置呢?下面我们就来看看详细的教程,需要的朋友
- 很多朋友在开始菜单中找不到卸载程序,怎么办呢?不要着急,下面脚本之家小编给大家带来了win7开始菜单找不到卸载程序的解决方法,需要的朋友参考
- Win10预览版10051演示视频曝光,我们可以先体验一下,但是软官方并未推送Build 10051更新,因此不建议大家安装Build 10
- 4 月 9 日消息 今日凌晨,苹果面向开发者发布了 macOS Big Sur 11.3 开发者预览版的第七个测试版本。macOS Big
- Win10专业版系统电脑用户电脑在默认情况下开启了快速启动功能,导致每次开机都非常慢而且有时还会出现无法关闭电脑的问题,那么,Win10专业
- 当你在编辑一些重要的文档资料时,想要告知对方这篇文档的重要性或者原创性。这时在文档中添加水印就是一个不错的选择。它不影响阅读,又能起到提示的
- 相信大家都清楚显存的大小直接影响了游戏的运行效果,显存越高代表显卡的处理性能就越强。但是对于如何查看显存的方法,估计知道的人不多。接下来就为
- Win10中最新版Chrome Canary报错该怎么办?win10中使用Chrome打开网页时出现Aw Snap, Something w
- 在很多电脑中,都有蓝牙功能,特别是笔记本电脑,有些用户根本用不着蓝牙,或者说不喜欢使用蓝牙,并且也不像有任何蓝牙设备连接自己的电脑,那么该怎
- excel是工作中最常用到的表,如果在对数据进行接触的过程中遇到小数点后出现很多位,而只需要两位小数的情况,该怎么保留?下面就跟小编一起来看
- 对于很多想要升级Win11系统的用户来说,在加入用户预览体验计划的时候会让用户选择哪一个渠道来进行升级Win11。很多用户对于哪个渠道并不了
- Excel绘制带涨跌箭头的柱形图基础数据与图表效果第一步单击数据区域任意单元格,点击【插入】【簇状柱形图】。插入一个默认样式的柱形图。第二步
- 很多朋友目前都有需要重装系统的需要,现在在网上很多操作系统的下载都是iso镜像文件。那么下载好这些镜像文件要怎么安装系统呢?下面小编就教下大
- 我们在写论文过程中,在Word文档里输入MathType写的公式,发现公式与文字不能很好得对齐问题,上下有偏差,很丑,让人很不爽;还有很多人
- 据系统部落8月10日消息,又到了每周二补丁日,微软向Win11正式版用户推送了8月累积更新补丁KB5016629,其中包括针对安全漏洞、错误
- 如何制作网线?大家的生活都离不开网络,而网络就需要用到网线。网线看起来简单,要制作并不是那么容易。为了解决大部分用户的困惑,今天小编将给大家
- 中间数值从两边分别取出5,现在需要增加两列辅助数据。圆环图本身所需的数据包含两个数据。在圆环中由这两个数据共同分配360度的扇区角度, 步骤