函数周期表丨模糊匹配

CONTAINSSTRING函数

CONTAINSSTRINGEXACT函数

CONTAINSSTRING函数被微软划分为“信息”函数,属于“值函数”,根据判定结果返回TRUE或者FALSE。

CONTAINSSTRINGEXACT函数和其效果几乎是完全一样。

二者总体来说使用的方式差不多,一些细节的地方有些出入,都是用来检查字符是否被包含。

用途:可用于模糊匹配或者查询匹配。

原本白茶的计划是按照微软的函数划分对函数进行逐个的讲解,
但是在2020.9月底左右,微软修改了DAX函数的类别划分,
一度导致白茶的函数思路崩溃…
白茶思考了很久,决定摒弃掉之前的思路,按照函数的实际用途去阐述,总体风格会有细节上的变动。

语法

语法1:

DAX=CONTAINSSTRING(<within_text>, <find_text>)

语法2:

DAX=CONTAINSSTRINGEXACT(<within_text>, <find_text>)

参数

within_text:被查找的范围。

find_text:需要查找的文本内容。

返回结果

TRUE或者FALSE

区别

CONTAINSSTRING支持通配符,不区分大小写;

CONTAINSSTRINGEXACP不支持通配符,区分大小写。

通配符规则

  • 问号(?):问号匹配任何单个字符

  • 星号(*):星号匹配任何字符序列

  • 如果你想找到的是问号或星号本身,请在字符前键入一个波浪号(~)

例子

例子1:

输入如下代码。

CONTAINSSTRING =
ROW (
    "例子1", CONTAINSSTRING ( "红橙黄绿", "橙黄" ),
    "例子2", CONTAINSSTRING ( "红橙黄绿", "橙绿" ),
    "例子3", CONTAINSSTRING ( "红橙黄绿", "橙*绿" ),
    "例子4", CONTAINSSTRING ( "红橙黄绿", "黑白" )
)

结果如下:

结果一目了然,根据查找内容决定输出结果。

例子2:

模拟数据:

这是白茶随机模拟的数据,之前的一期白茶使用过这个案例数据。

传送门:《销售需求丨查找问题》

在这个情境中,也可以使用本期的函数来进行单个颜色的模糊匹配。

代码1:

CONTAINSSTRING =
VAR SLL =
    VALUES ( '维度'[维度] )
VAR SQL =
    MAX ( '事实表'[颜色] )
RETURN
    IF ( CONTAINSSTRING ( SQL, SLL ), SQL )

代码2:

CONTAINSSTRINGEXACT =
VAR SLL =
    VALUES ( '维度'[维度] )
VAR SQL =
    MAX ( '事实表'[颜色] )
RETURN
    IF ( CONTAINSSTRINGEXACT ( SQL, SLL ), SQL )

其结果如下:

小伙伴们❤GET了么?

白茶会不定期的分享一些函数卡片

(文件在知识星球[PowerBI丨需求圈])

这里是白茶,一个PowerBI的初学者。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Fabric丨白茶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值