excel的XLOOKUP的快速多列关联查询

我们前几章上面介绍了,根据某国产品牌官网介绍的使用&连接来进行多列关联查询,非常的慢。有没有公式可以快速进行XLOOKUP多列关联查询,我们找到了一个速度还可以的办法。

原理:有几列需要关联查询,我们就写几个XLOOKUP的单列查询。然后用AND语句,检查这些XLOOKUP的结果是否正确。再用IF语句,将AND作为逻辑值。用其中一个XLOOKUP的单列查询作为真值,null作为假值。这样的语句,比用&连接的语句效率要高非常多,100万条数据大概只需要30秒左右就计算出来了。

来看一下公式:

=IF(

AND

(

XLOOKUP(B2,Sheet2!$B2:B8,Sheet2!D2:D$8,"NULL")<>"NULL",

XLOOKUP(C2,Sheet2!$C2:C8,Sheet2!D2:D$8,"NULL")<>"NULL",

XLOOKUP(D2,Sheet2!$E2:E8,Sheet2!D2:D$8,"NULL")<>"NULL"

)

,XLOOKUP(C2,Sheet2!$C2:C8,Sheet2!D2:D$8,"NULL"),"NULL")

上面的公式,看起来有点吓人,我们用颜色做了区分。它的意思就是:如果b、c、d三列都相等,用xlookup取d列的值。

在excel2021以上版本测试,速度很快。在国产某品牌也测试过,不公布结果。

这种IF(and(),,)或者IF(OR(),,)或者二者组合的模式,将单列查询变成多列查询,成为了一种可能。不光适用于XLOOKUP,其他函数也同样可以。

相关推荐
一名技术极客17 分钟前
Vue2 doc、excel、pdf、ppt、txt、图片以及视频等在线预览
pdf·powerpoint·excel·文件在线预览
用余生去守护35 分钟前
【反射率】-- Lab 转换(excel)
excel
进击的六角龙37 分钟前
Python中处理Excel的基本概念(如工作簿、工作表等)
开发语言·python·excel
TracyDemo37 分钟前
excel功能
excel
lc寒曦38 分钟前
【VBA实战】用Excel制作排序算法动画
排序算法·excel·vba
zzzgd81641 分钟前
easyexcel实现自定义的策略类, 最后追加错误提示列, 自适应列宽,自动合并重复单元格, 美化表头
java·excel·表格·easyexcel·导入导出
努力学习技能的LY41 分钟前
Excel:vba实现批量插入图片批注
excel
图片转成excel表格2 小时前
wps怎么算出一行1和0两种数值中连续数值1的个数,出现0后不再计算?
excel·wps
q2498596933 小时前
前端预览word、excel、ppt
前端·word·excel
丁德双17 小时前
winform 加载 office excel 插入QRCode图片如何设定位置
c#·excel