excel部分字段相同模糊匹配_Power BI—高级模糊匹配会吗?VBA和函数统统闪开

本文介绍了如何在Excel中进行单向和双向模糊匹配。对于单向模糊匹配,使用VLOOKUP函数结合通配符'*'可以实现。而对于双向模糊匹配,当两表数据都模糊时,传统函数难以解决,但Power Query的「模糊匹配」功能可以快速完成这一任务,只需设置匹配阈值即可。注意,尽管有模糊匹配工具,仍需尽量规范化数据源。
摘要由CSDN通过智能技术生成

Excel中这两类数据如何匹配?Excel中如何进行模糊匹配?Excel如何匹配模糊的两张表?这一类问题在学习群中被提及的频率非常高,主要的场景有:

  1. 表A的数据是精确的匹配模糊的表B;
  2. 表A的数据是模糊的匹配精确的表B;
  3. 表A和表B的数据都是模糊的进行匹配;

看着是不是非常的绕?其实99%的概率这些场景你都碰到过。

- 01 -

单向模糊匹配

首先来看下简单场景下的模糊匹配,即匹配的两张表中有一张是精确的,例如下方的「产品销量表」和「产品单价表」。

其中「产品销量表」的产品是精准缩减版的,而另外一张表的产品则附加有其他的信息:

3a6fb48f5010df8fdca665e900cc2833.png

问题来了, 如何在「产品销量表」中匹配出「单价」,其实在Excel中存在这一个通配符「*」。

我们可以利用这个符号配合VLOOKUP函数快速来实现单向的模糊匹配。

公式:=VLOOKUP("*"&A2&"*",E:F,2,0)

48587e80559a770695e1b3e8745a3062.png

非常轻松就完成了,这里表示什么意思呢?其实理解也不难。

使用&连接符号将「*」和「检索关键字」连接在一起。

字符「产品A」就变成了「*产品A*」,这样就可以实现模糊匹配了。

另外来讲解下新手在这里经常会犯的一个错误就是写成下面这几种:

  1. =VLOOKUP(*A2*,E:F,2,0),不使用&连接;
  2. =VLOOKUP(A2,E:F,2,1),改变为模糊匹配就是真正的模糊匹配?

这里的「*」是字符串,连接需要使用&符号。

而VLOOKUP的最后一个参数设置为1,实际上是数值从小到大的模糊匹配。

跟文本的这种模糊匹配没有任何关系,使用限制也非常多。

- 02 -

双向模糊匹配

了解完单向的简单模糊匹配,我们使用VLOOKUP函数+星号就可以轻松完成。

如果两张表都是「模糊」的呢?就像下面这种:

395f6099ff40f2552bf0feb42b563ea2.png

销量表」的部分产品带有前缀,而「单价表」的部分产品带有尺码信息,那么像这种表一般如何匹配呢?

这种情况下,函数一般就非常难解决了,而且兼容性差,一般情况下都使用VBA来完成,但是写代码门槛比较高。

其实在PQ中也有一项「模糊匹配」的功能,可以快速实现这个需求,首先将两张表导入到BI中,如下:

c566bc4df9832ad529f862028131772a.png

接着在任意一张表中点击「主页」选项卡下的「将查询合并为新查询」,操作两张表的匹配字段,同时勾选「模糊匹配」。

d5a1cb30d4ae4c554649958595c52e5b.gif

在「模糊匹配选项」中可以看到这里有一些参数需要我们配置,其中最重要的就是「阈值」。

这里的「阈值」是什么意思呢?比如「产品A」和「产品A-代码」的匹配度是多少呢?有3个字符是匹配的,而总字符是6个。

所以匹配度是50%,我们需要简单计算下两张表的匹配阈值,这里我们填写0.5。

然后点击确定,将「销量」筛选出来:

13b017a9f063a6382d185f3dc95eb40b.gif

现在是不是就轻松完成了两张模糊表格之间的双向匹配,是不是非常简单呢?一行代码都没写,10秒钟不到,搞定。

这个功能只有在Power BI中才有,如果是Excel中的PQ,是没有这个功能的,仍然需要使用VBA。

另外不要因为有模糊匹配功能,就可以对源数据不加约束,依然应该尽量规范你的数据源,能保持一致最好。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值