百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

Power BI—高级模糊匹配会吗?VBA和函数统统闪开

yuyutoo 2024-10-20 13:07 10 浏览 0 评论

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


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


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


- 01 -

单向模糊匹配


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


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



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


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


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



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


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


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


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


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


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


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


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


- 02 -

双向模糊匹配


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


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



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


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


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



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



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


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


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


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



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


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


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


相关推荐

Java的经典垃圾收集器G1,如何设置参数,什么场景下适用?

G1(Garbage-First)是一款面向服务器的垃圾收集器,主要针对配备多颗处理器及大容量内存的机器.以极高概率满足GC停顿时间要求的同时,还具备高吞吐量性能特征。G1将Java堆划分为多个大...

这份Java面试八股文让329人成功进入大厂,堪称2021最强

前言2021秋招即将来临,很多同学会问Java面试八股文有必要背吗?我的回答是:很有必要。你可以讨厌这种模式,但你一定要去背,因为不背你就进不了大厂。国内的互联网面试,恐怕是现存的、最接近科举考试的制...

JDK成长记7:3张图搞懂HashMap底层原理

...

深度解析HashMap集合底层原理(hashmap集合特点)

目录...

网络安全之对文件上传的思考(文件上传功能中出现安全问题)

在web渗透中,最简单直接的方式就是文件上传。但是不做任何检测,直接getshell的现在已经很少了.我在平时的授权测试中,遇到的大多数都是对上传的文件内容,格式等检测的比较多的按前端到后端绕过顺序分...

JVM常用参数自查笔记(jvm参数怎么看)

配置堆区:-Xms、-Xmx、-XX:newSize、-XX:MaxnewSize、-Xmn;-Xms:表示java虚拟机堆区内存初始内存分配的大小,通常为操作系统可用内存的1/64大小即可,但仍...

JAVA集合(java集合类有哪些分别有什么特点)

JAVA集合1.接口集成关系和实现集合类存放于Java.util包中,主要有3种:set(集)、list(列表包含Queue)和map(映射)。1.Collection:Collection...

体育老师教你学Java语言(中篇)(教java的老师)

一、控制结构训练营1.条件语句if-else→赛前资格审查...

十年之重修ConcurrentHashMap原理

弱小和无知并不是生存的障碍,傲慢才是。...

安装JDK(安装jdk的详细步骤)

JDK下载地址:JDK组成:javac:编译器,将源程序转成字节码。jar:打包工具,将相关的类文件打包成一个文件。javadoc:文档生成器,从源码注释中提取文档。jdb:debugger,查错...

零基础编程入门!手把手教你学Java

...

CentOS 7 上安装 JDK 8 的步骤:(centos7下载jdk)

CentOS7上安装JDK8的步骤:一、下载JDK...

JDK为什么废弃永久代,而引入元空间

今天我们来说说这个JVM的相关知识,因为面试简直是问到麻木的问题,那就是关于JVM的相关知识,今天了不起再次来和大家聊一下这个知识,我们从一些比较奇怪的问题说起,也不说那些经常会问到的内容了,...

JDK 1.8中对象被访问的具体过程及步骤

JDK1.8中对象被访问的过程和步骤对象的创建与初始化当使用new关键字创建一个Java对象时,JVM需要执行以下步骤:...

JDK21有没有什么稳定、简单又强势的特性?

佳未阿里云开发者...

取消回复欢迎 发表评论: