财务分析报告 - 常用Power BI DAX公式详解

财务分析报告 - 常用Power BI DAX公式详解

摘要

此篇来自对power bi gallery中,上市公司财务分析报告的DAX解析。

我用小龙虾读取了这个报告的公式,让其进行提取,说明,以及关键知识点的说明。

主要用于后续知识的review。


一、时间智能函数

1. 同比分析 (Year-over-Year)

营收同比
DAX 复制代码
营收同比 = 
VAR CurrentRevenue = SUM('利润表'[营业收入])
VAR LastYearRevenue = CALCULATE(
    SUM('利润表'[营业收入]),
    SAMEPERIODLASTYEAR('日期表'[日期])
)
RETURN
    DIVIDE(CurrentRevenue - LastYearRevenue, LastYearRevenue)

作用:计算本期营业收入与去年同期的增长百分比

知识点

  • SAMEPERIODLASTYEAR():返回去年同期的日期集合
  • CALCULATE():修改计算上下文,是 DAX 最强大的函数
  • DIVIDE():安全除法,避免除零错误
净利润同比
DAX 复制代码
净利润同比 = 
VAR CurrentNetProfit = SUM('利润表'[净利润])
VAR LastYearNetProfit = CALCULATE(
    SUM('利润表'[净利润]),
    SAMEPERIODLASTYEAR('日期表'[日期])
)
RETURN
    DIVIDE(CurrentNetProfit - LastYearNetProfit, LastYearNetProfit)
扣非净利润同比
DAX 复制代码
扣非净利润同比 = 
VAR CurrentExcluding = SUM('利润表'[扣非净利润])
VAR LastYearExcluding = CALCULATE(
    SUM('利润表'[扣非净利润]),
    SAMEPERIODLASTYEAR('日期表'[日期])
)
RETURN
    DIVIDE(CurrentExcluding - LastYearExcluding, LastYearExcluding)

2. 累计计算 (Running Total)

年初至今营收
DAX 复制代码
年营收 = TOTALYTD(
    SUM('利润表'[营业收入]),
    '日期表'[日期]
)

知识点

  • TOTALYTD():计算年初至今的累计值
  • 参数可选:年结束月份,如 TOTALYTD(SUM(Sales[Amount]), Dates[Date], "06/30")
年初至今净利润
DAX 复制代码
年净利润 = TOTALYTD(
    SUM('利润表'[净利润]),
    '日期表'[日期]
)

二、比率计算函数

1. 盈利能力指标

毛利率
DAX 复制代码
毛利率 = DIVIDE(
    SUM('利润表'[营业收入]) - SUM('利润表'[营业成本]),
    SUM('利润表'[营业收入])
)

等价形式

DAX 复制代码
毛利率 = 
VAR Revenue = SUM('利润表'[营业收入])
VAR COGS = SUM('利润表'[营业成本])
RETURN
    1 - DIVIDE(COGS, Revenue)
净利率
DAX 复制代码
净利率 = DIVIDE(
    SUM('利润表'[净利润]),
    SUM('利润表'[营业收入])
)
净资产收益率 (ROE)
DAX 复制代码
净资产收益率 = DIVIDE(
    SUM('利润表'[净利润]),
    AVERAGE('资产负债表'[所有者权益])
)

说明:反映股东投资回报率,是杜邦分析的核心指标

总资产收益率 (ROA)
DAX 复制代码
总资产收益率 = DIVIDE(
    SUM('利润表'[净利润]),
    AVERAGE('资产负债表'[总资产])
)

知识点

  • AVERAGE():计算平均值,自动忽略空白
  • 需使用平均资产,因为资产负债表是时点数据

2. 偿债能力指标

资产负债率
DAX 复制代码
资产负债率 = DIVIDE(
    SUM('资产负债表'[负债总额]),
    SUM('资产负债表'[资产总额])
)
流动比率
DAX 复制代码
流动比率 = DIVIDE(
    SUM('资产负债表'[流动资产]),
    SUM('资产负债表'[流动负债])
)
速动比率
DAX 复制代码
速动比率 = DIVIDE(
    SUM('资产负债表'[流动资产]) - SUM('资产负债表'[存货]),
    SUM('资产负债表'[流动负债])
)
现金流量比率
DAX 复制代码
现金流量比率 = DIVIDE(
    SUM('现金流量表'[经营活动产生的现金流量净额]),
    SUM('资产负债表'[流动负债])
)

3. 营运能力指标

存货周转率
DAX 复制代码
存货周转率 = DIVIDE(
    SUM('利润表'[营业成本]),
    AVERAGE('资产负债表'[存货])
)

知识点:周转率越高,说明存货管理效率越好

存货周转天数
DAX 复制代码
存货周转天数 = 365 / [存货周转率]

或使用

DAX 复制代码
存货周转天数 = DIVIDE(365, [存货周转率])
应收账款周转天数
DAX 复制代码
应收账款周转天数 = DIVIDE(
    365 * AVERAGE('资产负债表'[应收账款]),
    SUM('利润表'[营业收入])
)
总资产周转率
DAX 复制代码
总资产周转率 = DIVIDE(
    SUM('利润表'[营业收入]),
    AVERAGE('资产负债表'[总资产])
)

4. 现金流指标

净现比
DAX 复制代码
净现比 = DIVIDE(
    SUM('现金流量表'[经营活动产生的现金流量净额]),
    SUM('利润表'[净利润])
)

知识点

  • 反映利润的现金质量
  • 正常应大于 1,表示利润有真实现金支撑
  • 长期小于 1 可能意味着盈利质量不佳
每股经营现金流
DAX 复制代码
每股经营现金流 = DIVIDE(
    SUM('现金流量表'[经营活动产生的现金流量净额]),
    SUM('公司基本信息'[总股本])
)

三、DAX 核心概念

1. 上下文 (Context)

行上下文 (Row Context)
  • 迭代函数(如 SUMX, AVERAGEX)创建行上下文
  • 在每一行上计算表达式
DAX 复制代码
Total Cost := SUMX(
    Sales,
    Sales[Quantity] * Sales[Unit Cost]
)
筛选上下文 (Filter Context)
  • 由视觉对象(图表、切片器)创建的过滤条件
  • CALCULATE() 可以修改筛选上下文
DAX 复制代码
Sales Red := CALCULATE(
    SUM(Sales[Amount]),
    Sales[Color] = "Red"
)
上下文转换
  • 行上下文在 CALCULATE 内自动转换为筛选上下文
  • 这是 DAX 最强大的特性之一

2. 常用迭代函数

函数 说明 示例
SUMX() 对表逐行计算后求和 SUMX(Sales, Sales[Qty] * Sales[Price])
AVERAGEX() 逐行计算后取平均 AVERAGEX(Sales, Sales[Amount])
COUNTX() 计数非空白值 COUNTX(Sales, Sales[OrderID])
CONCATENATEX() 串联文本 CONCATENATEX(Values, Table[Name], ", ")
MAXX() / MINX() 最大/最小值 MAXX(Sales, Sales[Amount])

3. 筛选函数

FILTER
DAX 复制代码
HighValueSales := CALCULATE(
    SUM(Sales[Amount]),
    FILTER(
        Sales,
        Sales[Amount] > 1000
    )
)
ALL
DAX 复制代码
PercentOfTotal := DIVIDE(
    SUM(Sales[Amount]),
    CALCULATE(SUM(Sales[Amount]), ALL(Sales))
)

作用:移除所有筛选,获取总计

ALLEXCEPT
DAX 复制代码
PercentByCategory := DIVIDE(
    SUM(Sales[Amount]),
    CALCULATE(SUM(Sales[Amount]), ALLEXCEPT(Sales, Sales[Category]))
)
VALUES / DISTINCT
DAX 复制代码
CategoryCount := COUNTROWS(VALUES(Sales[Category]))

4. 时间智能函数

函数 功能
SAMEPERIODLASTYEAR() 去年同周期
PARALLELPERIOD() 偏移N个月/季度/年
DATEADD() 日期偏移
TOTALYTD() 年初至今累计
TOTALQTD() 季度至今累计
TOTALMTD() 月初至今累计
DATESYTD() 年初至今日期集
ENDOFMONTH() / ENDOFQUARTER() 月/季度末日期

5. 关系函数

DAX 复制代码
ProductCategory := RELATED('Product'[Category])

前提:必须存在一对多关系

RELATEDTABLE
DAX 复制代码
SalesCount := COUNTROWS(RELATEDTABLE(Sales))

6. 变量 (VAR)

DAX 复制代码
ComplexMeasure := 
VAR TotalSales = SUM(Sales[Amount])
VAR LastYearSales = CALCULATE(SUM(Sales[Amount]), SAMEPERIODLASTYEAR(Dates[Date]))
VAR YoY = TotalSales - LastYearSales
RETURN
    DIVIDE(YoY, LastYearSales)

优点

  • 提高可读性
  • 避免重复计算
  • 可存储多个中间结果

四、杜邦分析公式

杜邦恒等式

DAX 复制代码
净资产收益率 = 净利率 × 资产周转率 × 权益乘数

权益乘数

DAX 复制代码
权益乘数 = DIVIDE(
    SUM('资产负债表'[总资产]),
    SUM('资产负债表'[所有者权益])
)

分解后的 ROE

DAX 复制代码
ROE分解 := 
    [净利率] * [总资产周转率] * [权益乘数]

五、同行比较公式

行业中位数

DAX 复制代码
行业中位数 = MEDIANX(
    ALL('公司数据'),
    '公司数据'[市盈率]
)

知识点

  • MEDIAN():返回中位数(总体)
  • MEDIANX():返回中位数(迭代)

同行业中值

DAX 复制代码
同行业中值 = CALCULATE(
    MEDIAN('公司数据'[市盈率]),
    '公司数据'[行业] = SELECTEDVALUE('公司数据'[行业])
)

六、常见错误与最佳实践

1. 常见错误

错误 原因 解决
空白结果 上下文不匹配 使用 CALCULATE 调整
值过大 未正确筛选 检查筛选上下文
时间函数不工作 缺少日期表 创建连续日期表并标记

2. 最佳实践

  1. 始终创建日期表
DAX 复制代码
日期表 = CALENDAR(DATE(2020,1,1), TODAY())
  1. 标记日期表
DAX 复制代码
MARKASFIRED('日期表')
  1. 使用度量值而非直接列计算

  2. 复杂公式使用变量

  3. 避免在度量值中使用硬编码


七、公式速查表

业务指标 基础公式
同比增长率 (本期-上期) / 上期
环比增长率 (本期-上期) / 上期
毛利率 (营收-成本) / 营收
净利率 净利润 / 营收
ROE 净利润 / 净资产
ROA 净利润 / 总资产
资产负债率 负债 / 资产
流动比率 流动资产 / 流动负债
周转率 成本或收入 / 平均余额
每股收益 净利润 / 股数
相关推荐
数据科学小丫8 天前
Power BI 使用
数据分析·数据可视化·powerbi
Sharewinfo_BJ17 天前
数据可视化新维度:Power BI Unicode 应用实战指南
信息可视化·数据挖掘·数据分析·powerbi
雾岛心情23 天前
【PowerBI专栏】PowerQuery实现按列分行和按列分列
powerbi
Sharewinfo_BJ2 个月前
PowerBI 2026年1月功能更新|效率升级,体验再优化
windows·microsoft·powerbi
y5236482 个月前
PowerBI 简单示例,表格显示当前日期的上一次日期
powerbi
weixin_318088112 个月前
Power query代替PowerBI加载数据到excel
excel·powerbi·power query
牛猫Data3 个月前
Power BI为什么不能完全取代Excel?
microsoft·数据分析·excel·database·数据可视化·powerbi
weixin_465790913 个月前
16台搅拌机定时控制:三菱PLC与威伦通触摸屏的奇妙组合
powerbi
醉卧考场君莫笑3 个月前
PowerBI(上)
信息可视化·数据分析·powerbi