用好Xlookup函数,查询引用不再烦恼,条件及逆向查询统统搞定
yuyutoo 2025-01-02 20:10 1 浏览 0 评论
Lookup以及Vlookup函数,是Excel中应用最广泛的函数,但在2019年,微软公布了Xlookup函数,但只能在Office 365版本中使用;如果你使用的是版本较低的Office,也可以在新版的WPS中使用,和VLOOKUP函数相比,只是将字母V变成了X,但其功能确发生了很大的变化。
功能:在某个范围或数组中搜索匹配项,并通过第二个范围或数组返回相应的项,默认情况下使用精准匹配。
语法结构:=Xlookup(查询值,查询值范围,返回值范围,[未查询到值时的返回值],[匹配模式],[搜索模式])。
解读:
1、 参数“查询值”、“查询值范围”、“返回值范围”很好理解,就是字面意思,其中“值”就是指定的字段或单元格地址,“范围”就是单元格的区域。
2、参数“未查询到值时的返回值”是指:在查询值范围中未找到要查询的值时,返回的指定值,在Vlookup函数中,如果查询不到指定的值,则返回#N/A,但在Xlookup中,可以指定具体的值,如果省略则返回#N/A。
3、参数“匹配模式”共有4种,分别为0、-1、1、2。其中0为精准匹配;-1为精准匹配或下一个较小的项;1为精准匹配或下一个较大的项;2位通配符匹配;省略时默认为精准匹配。
4、参数“搜索模式”共有4种,分别为1、-1、2、-2。其中1为从第一项到最后一项全部搜索;-1为从最后一项到第一项搜索;2为二进制文件搜索(升序模式);-2为二进制文件搜索(降序模式)。省略时默认从第一项到最后一项全部搜索。
如果要用好Xlookup函数,参数中后3个参数代码的意思是必须要掌握的,可以不用强迫记忆,在使用时根据系统的联想功能填充即可。
下面我们从具体的案例了解和掌握Xlookup函数的用法。
一、普通查询。
目的:根据员工姓名查询对应的月薪。
方法:
在目标单元格中输入公式:=XLOOKUP(J3,C3:C12,H3:H12)。
解读:
1、此方法中应用了Xlookup必须的3个参数,其省略的参数全部按照默认的值执行。
二、多条件查询。
如果只有如下图的基础数据,该如何查询“李丽”的“月薪”呢?
通过对数据源的分析,我们不难发现,“李丽”有2个人,除了性别不同外,其它基础信息均相同,此时,我们要精准的查询李丽的月薪,就需要增加条件。即通过姓名和性别两个条件来查询。
目的:通过员工姓名和性别查询对应的月薪。
方法:
在目标单元格中输入公式:=XLOOKUP(I3&J3,B3:B12&D3:D12,G3:G12)。
解读:
如果此功能用VLOOKUP函数去实现,公式该如何去编辑了?但如果用Xlookup函数,条件及数据区域之间只需用“&”符号链接即可,是不是非常简单?
三、逆向查询。
目的1:根据员工的姓名查询对应的工号。
方法:
在目标单元格中输入公式:=XLOOKUP(J3,C3:C12,B3:B12)。
解读:
用Xlookup逆向查询时,只需将对应的数据范围填写到对应的参数区域即可,不需要重构数组等操作。
四、未找到查询内容时返回指定的内容。
目的:如果查询不到相关人员的信息,则返回“查无此人”。
方法:
在目标单元格中输入公式:=XLOOKUP(J3,C3:C12,H3:H12,"查无此人")。
解读:
如果不指定第4个参数,则默认返回值为错误代码#N/A。指定第4个参数后,公式和数据的可读性更强。
五、精准查询或向下匹配。
目的:查询等于或低于指定月薪的最高月薪员工姓名。
方法:
在目标单元格中输入公式:=XLOOKUP(J3,H3:H12,C3:C12,,-1)。
解读:
此用法的关键在于第5个参数,在前文中我们已经介绍过,“匹配模式”共有4种,当为-1时为精准匹配或下一个较小的项,也就是返回等于或小于当前值的最大值。
六、精准查询或向上匹配。
目的:查询等于或高于指定月薪的最低月薪员工姓名。
方法:
在目标单元格中输入公式:=XLOOKUP(J3,H3:H12,C3:C12,,1)。
解读:
如果明白了第5个示例,第六个示例也就很容易理解了,其关键还是在第5个参数,当参数值为1时为精准匹配或下一个较大的项,也就是返回等于或大于当前值的最小值。
七、从数据库的末尾逆向查询。
目的:查询产品最后一次的销售单价。
方法:
在目标单元格中输入公式:=XLOOKUP(J3,C3:C12,D3:D12,,0,-1)。
解读:
此用法的关键在于第6个参数,在前文中我们已经介绍过,“搜索模式”共有4种,当为-1时为从最后一项到第一项搜索,即从数据库的末尾逆向搜索。如果要从数据库的第一条记录开始查询,则将第6个参数修改为1或省略即可。
八、一对多查询。
目的:根据产品编号查询对应的所有信息。
方法:
在目标单元格中输入公式:=XLOOKUP(J3,B3:B12,C3:G12),并用Ctrl+Shift+Enter填充。
解读:
由于返回的时数组区域,所以必须用Ctrl+Shift+Enter填充。
最美尾巴:
本节课内容中我们重点介绍了Xlookup的用法,其实上述功能也可以用VLOOKUP或Lookup等函数完成,但具体该如何实现了,欢迎大家在留言区讨论哦!
相关推荐
- 如何在EXCEL中进行IP地址排序
-
Excel中排序IP地址是非常不友好的,它完全是通过首位进行排序,无法实现我们的实际效果。作为IT人员对于IP地址的真正诉求是想要从小到大排列。那么如何进行排序呢?在Excel中,我们可以使用如下函数...
- Excel揭秘!Left函数开启高效字符串左端截取模式
-
今日推荐:LEFT函数。目的:把一组身份证号码或者一组电话号码的敏感信息隐藏起来。...
- 五十一、UiPath字符串函数的介绍和使用(转)
-
一、字符串属性Length:是指字符串长度如:intlen=字符串变量.Length;Chars:是指字符串转换成字符数组,数组从0开始,通常配合Length属性使用如:System.Charc=...
- 打工人一定要会的Excel的15个技巧!
-
今天给各位打工人分享15个Excel常用的小技巧,废话不多说,直接开始!先给大家看一张快捷键速查表:1.Ctrl+C和Ctrl+V只是入门你可能已经很熟悉基本的复制粘贴,但如果你想让粘贴操作更高...
- go语言中字符串常用的系统函数
-
最近由于工作比较忙,视频有段时间没有更新了,在这里跟大家说声抱歉了,我尽快抽些时间整理下视频今天就发一篇关于go语言的基础知识吧!我这我工作中用到的一些常用函数,汇总出来分享给大家,希望对...
- 最全的 ES 重点内容整理(上)
-
●我们从很多年前就知道ES6,也就是官方发布的ES2015●从2015年开始,官方觉得大家命名太乱了,所以决定以年份命名●但是大家还是习惯了叫做ES6,不过这不重要●重要的是...
- 2024 最火的5个顶级白板应用,燃爆了!
-
大家好,很高兴又见面了,我是"...
- Excel Trim函数用法的6个实例,Excel 顽固空格的去除方法
-
在Excel中,Trim函数用于去文本的前后空格和字符之间的空格,但在去字符之间的空格时,它不会把所有空格都去除,而是留下一个空格;如果要把字符之间的所有空格都去掉,需要用Substitute函数...
- TS类型体操,看懂你就能玩转TS了
-
本文以Typescript4.5及以上版本为基础,于2022年02月07日在掘金首发本文要实现一种类型工具...
- 一种接地气的编码规则:废弃驼峰式命名,告别手敲基础代码。
-
一种好的编码规则,能提高工作效率。在软件编程领域内,“驼峰”式命名规则是首选方式,最早来源于Perl语言编程的畅销书《programPerl》(oRelly出版)的封面图片正是一匹骆驼,故而得名。...
- AI 应用开发最常用的解释型Python语言如何保护源代码
-
众所周知,解释型语言Python/JavaScript/Perl/Shell是在无需编译,可以直接运行,因此很难保护源代码,例如C、C++、JAVA属于编译型语言,运行之前需要先编译才能运行...
- 2020年树莓派的5种最佳编程语言
-
树莓派是最灵活的电脑之一。也许不是在硬件上,但是它的可操作性使它成为一个独立的类。树莓派跨越了电脑和编程之间的鸿沟,让每个人都能接触到电脑。因此,各个年龄段的编程爱好者都掀起了一股编程热潮。它允许他们...
- 5 种即将消亡的编程语言
-
每个编写代码的人都有自己喜欢的语言...
- [240610] 5 种 Non-Posix Shell 在 x-cmd 上的支持 | Perl 发布 5.40.0
-
5种非PosixSHell-nushell,fish,xonsh,csh,pwsh利用三天假期,我开始动手增加了对各种Non-Posixshell的x-cmd支持。在这个过程中,...
- Linux批量修改文件名及强大的$\「\」用法介绍
-
一:Rename命令rename命令用字符串替换的方式批量改变文件名。rename命令有两个版本,一个是c语言版本的,一个是perl语言版本的,判断方法:vim`whichrename`C语言版本...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)