PowerBi中VALUES怎么使用?

VALUES() 是 Power BI / DAX 中一个非常重要的函数,常用于处理 上下文中的唯一值集合 。它既可以作为一种"上下文探测工具",也常用于配合 CALCULATE()COUNTROWS() 等函数实现一些高级逻辑。


✅ 一、VALUES 函数的定义

VALUES()

返回当前上下文中指定列的唯一值集合(去重后) ,并以"表"的形式返回。

它也可以写成:

DAX 复制代码
VALUES(Table[Column])

🧠 二、VALUES 的作用总结

用途 说明
获取当前上下文中的唯一值 可以知道当前筛选了哪些维度(如哪些客户/产品)
CALCULATE() 提供筛选器 配合 IN 使用,批量筛选
统计去重后的数量 配合 COUNTROWS() 计算去重数量
判断是否只有一个唯一值 配合 IF() 判断是否是单个上下文

📘 三、VALUES 的常见使用场景举例


✅ 1. 获取去重后的客户数量

DAX 复制代码
客户数量 = COUNTROWS(VALUES(Sales[客户]))

📌 意思是:统计当前筛选条件下,有多少个不重复的客户。


✅ 2. 用于 IN 多值筛选(配合 CALCULATE)

DAX 复制代码
产品销售额 =
CALCULATE(
    SUM(Sales[销售额]),
    Products[产品] IN VALUES(TopProducts[产品])
)

📌 意思是:只计算属于 TopProducts 表中产品的销售额。


✅ 3. 判断当前上下文是否只有一个唯一值

DAX 复制代码
当前产品名称 =
IF(
    HASONEVALUE(Products[产品]),
    VALUES(Products[产品]),
    "多个产品"
)

📌 意思是:如果当前上下文只有一个产品,就显示它的名字;否则提示"多个产品"。


✅ 4. 与 SELECTEDVALUE() 对比

SELECTEDVALUE() 实际上就是 IF(HASONEVALUE(), VALUES(), default) 的简写:

DAX 复制代码
-- 等价于
SELECTEDVALUE(Products[产品], "多个产品")

⚠️ 四、注意事项

说明
返回值是"表" VALUES() 返回的是一张一列的表,而不是单个值
用在 IF() 时需配合 HASONEVALUE() 避免 VALUES() 返回多行时报错
不等于 DISTINCT() DISTINCT() 会保留空值;VALUES() 在无上下文时返回所有值,包含空

✅ 五、总结一句话:

VALUES() 是获取当前上下文中唯一值集合的万能工具,适合做判断、去重、动态筛选等,是 DAX 中非常核心的函数之一。

相关推荐
用户Taobaoapi20148 小时前
母婴用品社媒种草效果量化:淘宝详情API+私域转化追踪案例
大数据·数据挖掘·数据分析
key0613 小时前
电子水母函数解析
数据分析
Brduino脑机接口技术答疑15 小时前
脑机新手指南(二十一)基于 Brainstorm 的 MEG/EEG 数据分析(上篇)
数据挖掘·数据分析
镜舟科技15 小时前
StarRocks × Tableau 连接器完整使用指南 | 高效数据分析从连接开始
starrocks·数据分析·数据可视化·tableau·连接器·交互式分析·mpp 数据库
好开心啊没烦恼17 小时前
Python 数据分析:DataFrame,生成,用字典创建 DataFrame ,键值对数量不一样怎么办?
开发语言·python·数据挖掘·数据分析
永洪科技1 天前
永洪科技荣获商业智能品牌影响力奖,全力打造”AI+决策”引擎
大数据·人工智能·科技·数据分析·数据可视化·bi
Triv20251 天前
ECU开发工具链1.10版:更强大的测量、校准与数据分析体验.
microsoft·数据分析·汽车电子开发·校准流程自动化·高速信号采集·测试台架集成·实时数据监控
好开心啊没烦恼1 天前
Python 数据分析:numpy,抽提,整数数组索引与基本索引扩展(元组传参)。听故事学知识点怎么这么容易?
开发语言·人工智能·python·数据挖掘·数据分析·numpy·pandas
陈敬雷-充电了么-CEO兼CTO2 天前
推荐算法系统系列>推荐数据仓库集市的ETL数据处理
大数据·数据库·数据仓库·数据挖掘·数据分析·etl·推荐算法
马特说2 天前
React金融数据分析应用性能优化实战:借助AI辅助解决18万数据量栈溢出Bug
react.js·金融·数据分析