Excel中的“自动筛选”功能大家也许并不陌生,对于条件简单的筛选操作,它基本可以应付。但是,最后符合条件的结果只能显示的在原有的数据表格中,不符合条件的将自动隐藏。若要筛选含有指定关键字的记录,并且将结果显示在两个表中进行数据比对或其他情况,“自动筛选”就有些捉襟见肘了。“傻瓜相机”毕竟功能有限,那么就让我们来试试“高级相机”吧!熟练运用“高级筛选”,无论条件多么复杂,都能一网筛尽。人力资源部的小李最近在做员工表格统计时,就尝到了甜头。
设置筛选条件区
高级筛选的前提是在数据表的空白处设置一个带有标题的条件区域,这个条件区有3个注意要点:
·条件的标题要与数据表的原有标题完全一致;
·多字段间的条件若为“与”关系,则写在一行;
·多字段间的条件若为“或”关系,则写在下一行。
写条件时要遵守的规则是:
1、要在条件区域的第一行写上条件中用到的字段名,比如要筛选数据清单中“年龄”在30岁以上,“学历”为本科的职员,其中“年龄”和“学历”是数据清单中对应列的列名,称作字段名,那么在条件区域的第一行一定是写这两个列的名称(字段名),即“年龄”和“学历”,而且字段名的一定要写在同一行。
2、在字段名行的下方书写筛选条件,条件的数据要和相应的字段在同一列,比如上例中年龄为30岁,则“30”这个数据要写在条件区域中“年龄”所在列,同时“本科”要写在条件区域中“学历”所在的列。
在具体写条件时,我们要分析好条件之间是与关系还是或关系,如果是与关系,这些条件要写到同一行中,如是是或关系,这些条件要写到不同的行中,也就是说不同行的条件表示或关系,同行的条件表示与关系。
一、特定字符一步筛
现在在这份表格中,小李要查找姓“陈”的所有员工记录,他想了想,很快获得了结果。
如图1所示,在数据区域外的任一单元格(如B17)中输入被筛选的字段名称“姓名”,在紧靠其下方的B18单元格中输入筛选条件“陈*”。然后依次单击“数据→筛选→高级筛选”命令,在弹出的“高级筛选”对话框,选择筛选方式中的“将筛选结果复制到其他位置”单选按钮。将“列表区域”设置为“$A$1:$F$15”,“条件区域”设置为“$B$17:$B$18”,“复制到”设置为“$A$20:$F$20”,单击“确定”按钮,系统便自动将符合条件的记录筛选出来,并复制到指定的从A20开始的单元格区域中(如图2所示)。
小提示:如果在图1的B18单元格中输入筛选条件“*陈”,可筛选名字中含有“陈”字的员工记录(即“陈”字不一定是名字中的第一个字,该字可在名字中的任意位置)。
二、空白数据巧妙筛
接下来小李还需要查找没有职称员工的记录,如何进行呢?
如图3所示,他先在数据区域外的任一单元格(如E17)中输入被筛选的字段名称“职称”,然后在紧靠其下方的E18单元格中输入筛选条件“<>*”。
下一步,打开“高级筛选→将筛选结果复制到其他位置”,设置好“列表区域”、“条件区域”和“复制到”的位置,单击“确定”按钮,系统就自动将符合条件的记录筛选出来并复制到指定的单元格区域中(如图4所示)。
小提示:在本例中,如果要筛选的字段是数值型的,则需要将筛选条件更改为“=”(直接输入“=”号后按回车)。反过来,如果要筛选职称为非空的员工记录,只需将图3的筛选条件改为“*”即可。如果指定的筛选字段是数值型字段,则输入筛选条件“<>”。
三、满足多条件一起筛
更复杂的任务来了,这份表格需要查找满足多个条件的结果:男性、年龄不低于30岁、职称字段中含有“工程师”关键字的员工记录。这也难不倒小李。
如图5所示,在数据区域外的任一单元格区域(如A17:C17)中输入被筛选的字段名称“性别”、“年龄”和“职称”,在紧靠其下方的A18:C18单元格区域中分别输入筛选条件“男”、“>=30”和“*工程师”。然后进入“高级筛选→将筛选结果复制到其他位置”,设置好“列表区域”、“条件区域”和“复制到”的位置,确定,系统会自动将符合条件的记录筛选出来并复制到指定单元格区域中(如图6所示)。
小提示:如果将筛选条件输入在同一行中,筛选时系统会自动查找同时满足所有指定条件的记录并将其筛选出来。如果想查找所有字段值都是非空的员工记录,只需将指定的筛选条件文本型用“*”,数值型用“<>”,并将这些筛选条件输入在同一行中即可。
四、“多选一”也能筛
有时查找时,几个条件中如果满足一个即可,比如要查找年龄不低于30岁,或者职称为“高级工程师”的员工记录,又该如何筛选?
如图7所示,小李在数据区域外的任一单元格区域(如A17:B17)中输入被筛选的字段名称“年龄”和“职称”,在紧靠其下方的A18:B18单元格区域中分别输入筛选条件“>=30”和“高级工程师”。与以上方法类似,他选中“将筛选结果复制到其他位置”按钮后,设置好“列表区域”、“条件区域”和“复制到”的位置,确定,符合条件的记录就被筛选出来并复制到指定的单元格区域中了(如图8所示)。
小提示:在以上所有的筛选操作中,如果想使筛选结果不重复,只需选中“高级筛选”对话框中的“选择不重复的记录”复选框再进行相应的筛选操作即可。
小试牛刀,工作效率大大提高。“Excel高级筛选就像一块智能吸铁石,正确充分地利用好,要找的资料就能很快到手!想筛就筛,我筛得漂亮……”小李笑了。
Excel提供的“筛选”命令,可让我们方便地找到工作表中的记录。“筛选”包括了“自动筛选”和“高级筛选”。“自动筛选”简便易用,但条件设置缺乏灵活性。当“自动筛选”不能满足我们的需要时,可以考虑使用“高级筛选”,下面我们以图表1为例,一起来看看它的用法吧!
单列上具有多个条件
当我们要筛选姓名为“张三”或“田八”的学生。首先在工作表中数据区域的下方输入筛选条件如图表2,然后依次单击“数据”菜单、“筛选”、“高级筛选”,出现图表3对话框。在“方式”中选择“将筛选结果复制到其他位置”。单击“列表区域”右侧按钮,在工作表上选择图表1的数据区域,单击“条件区域”右侧按钮,在工作表上选择图表2的区域,单击“复制到”右侧按钮,在工作表中选择将筛选结果复制到的位置。单击“确定”后即可看到筛选结果。当然,也可在“方式”中选择“在原有区域显示筛选结果”,则“确定”后,可在原来数据区域的地方看到筛选后的结果,如果要恢复到原来的数据,单击菜单“数据”、“筛选”、“全部显示”。
单行上具有多个条件
当我们要筛选班级为“一”并且“成绩>90”的学生。在工作表中数据区域的下方输入筛选条件如图表4。其他操作同上。
多行多列具有多个条件
当我们要筛选班级为“一”或“成绩<60”的学生。在工作表中数据区域的下方输入筛选条件如图表5。其他操作同上。
当我们要筛选一班的成绩大于90分或者小于60分的学生,二班的成绩大于90或小于60的学生。在工作表中数据区域的下方输入筛选条件如图表6。其他操作同上。
当我们要筛选一班和二班的成绩大于60且小于90的学生。在工作表中数据区域的下方输入筛选条件如图表7。其他操作同上。
经过上面的条件设置我们大概也能看出其中的规律了,当我们把条件放在同一行时,表示同时要满足的条件,即“与”关系;当我们把条件放在不同行时,表示这些条件满足其一即可,即“或”关系。(严清秀)
小技巧
我们可以尝试把筛选条件写成“姓名”“张”,则经过上述操作后,我们看到的筛选结果有“张三”、“张七”,即把有所有姓名以“张”起始的都能被找出来。怎么实现精确筛选呢?只需把筛选条件“姓名”的下方输入“=张三”。为了防止系统认为我们输入的是个公式,可在编辑栏中输入“=张三”,输完按回车后,单元格中显示的是“张三”。