Power BI (DAX) 中的自定义日历 - 财政季度的计算列
Custom Calendar in Power BI (DAX) - Calculated column for Fiscal Quarter
我正在 Power Bi 中构建自定义日历。
我主要使用美国财政年度值,这意味着 2017 财政年度从 10 月 1 日 (2016-10-01) 开始并将于 9 月 30 日 (2017-09-30) 结束。所以,当前日历年度与财政年度的比较如下:
===============================================
Calendar YearMonth || Fiscal YearMonth
===============================================
201601 || 201604
201602 || 201605
201603 || 201606
201604 || 201607
201605 || 201608
201606 || 201609
201607 || 201610
201608 || 201611
201609 || 201612
201610 || 201701
201611 || 201702
201612 || 201703
为了计算月初至今、季度至今和年初至今的值,我需要一个工作日历。我试图解决这个问题的方法是,我已经创建了计算列。
我已经设法让财政年度和财政月份编号公式起作用:
Fiscal Year = IF(MONTH([DATE]) > 9, YEAR([DATE])+1, YEAR([DATE]))
Fiscal YearMonth No =
SWITCH(
TRUE(),
MONTH('Calendar'[Date]) = 10, 1,
MONTH('Calendar'[Date]) = 11, 2,
MONTH('Calendar'[Date]) = 12, 3,
MONTH('Calendar'[Date]) = 1, 4,
MONTH('Calendar'[Date]) = 2, 5,
MONTH('Calendar'[Date]) = 3, 6,
MONTH('Calendar'[Date]) = 4, 7,
MONTH('Calendar'[Date]) = 5, 8,
MONTH('Calendar'[Date]) = 6, 9,
MONTH('Calendar'[Date]) = 7, 10,
MONTH('Calendar'[Date]) = 8, 11,
MONTH('Calendar'[Date]) = 9, 12
)
但不幸的是,我似乎无法找出一个公式来获得财政年度季度号。我最近的尝试是将 SWITCH 函数与 DATESBETWEEN 一起使用,如下所示:
Fiscal YearQuarter No =
SWITCH(
TRUE(),
(DATESBETWEEN('Calendar',MONTH('Calendar'[Date]) >= 9, MONTH('Calendar'[Date])) <= 12)), 1,
(DATESBETWEEN ('Calendar'[Date],MONTH('Calendar'[Date]) >= 1, MONTH('Calendar'[Date]) <= 3)), 2,
(DATESBETWEEN ('Calendar'[Date],MONTH('Calendar'[Date]) >= 4, MONTH('Calendar'[Date]) <= 6)), 3,
(DATESBETWEEN ('Calendar'[Date],MONTH('Calendar'[Date]) >= 7, MONTH('Calendar'[Date]) <= 9)), 4
)
很遗憾,我遇到了语法错误。
由于 MONTH() 函数 returns 是一个整数值,我认为这就是为什么您使用 DATESBETWEEN() 函数包装它时会出现语法错误的原因。
相反,只需使用简单的整数运算符。我用这个计算测试了你的数据,它有效:
Fiscal YearQuarter No =
SWITCH(
TRUE(),
MONTH('Calendar'[Date])>=10 && MONTH('Calendar'[Date]) <= 12,1,
MONTH('Calendar'[Date])>=1 && MONTH('Calendar'[Date]) <= 3,2,
MONTH('Calendar'[Date])>=4 && MONTH('Calendar'[Date]) <= 6,3,
MONTH('Calendar'[Date])>=7 && MONTH('Calendar'[Date]) <= 9,4
)
此外,您可能不需要这么长的表达式来计算您的会计月份数字,因为您的会计日历与标准日历仅相差 3 个月。尝试用一个算术公式来代替它。这应该有效:
Fiscal YearMonth No= =
=IF((MONTH('Calendar'[Date])+3)>12,ABS(12-(MONTH('Calendar'[Date])+3)),(MONTH('Calendar'[Date])+3))
您可以像这样简单地将您的日历年更改为财政年
Fiscal Month = Orders[Order Date].[Month]
Fiscal Year = CONCATENATE("FY ",IF(Orders[Order Date].[MonthNo]>=4 && Orders[Order Date].[MonthNo]<=12,Orders[Order Date].[Year],Orders[Order Date].
[Year]-1))
这个财政年度是根据印度财政年度。
我正在 Power Bi 中构建自定义日历。
我主要使用美国财政年度值,这意味着 2017 财政年度从 10 月 1 日 (2016-10-01) 开始并将于 9 月 30 日 (2017-09-30) 结束。所以,当前日历年度与财政年度的比较如下:
===============================================
Calendar YearMonth || Fiscal YearMonth
===============================================
201601 || 201604
201602 || 201605
201603 || 201606
201604 || 201607
201605 || 201608
201606 || 201609
201607 || 201610
201608 || 201611
201609 || 201612
201610 || 201701
201611 || 201702
201612 || 201703
为了计算月初至今、季度至今和年初至今的值,我需要一个工作日历。我试图解决这个问题的方法是,我已经创建了计算列。
我已经设法让财政年度和财政月份编号公式起作用:
Fiscal Year = IF(MONTH([DATE]) > 9, YEAR([DATE])+1, YEAR([DATE]))
Fiscal YearMonth No =
SWITCH(
TRUE(),
MONTH('Calendar'[Date]) = 10, 1,
MONTH('Calendar'[Date]) = 11, 2,
MONTH('Calendar'[Date]) = 12, 3,
MONTH('Calendar'[Date]) = 1, 4,
MONTH('Calendar'[Date]) = 2, 5,
MONTH('Calendar'[Date]) = 3, 6,
MONTH('Calendar'[Date]) = 4, 7,
MONTH('Calendar'[Date]) = 5, 8,
MONTH('Calendar'[Date]) = 6, 9,
MONTH('Calendar'[Date]) = 7, 10,
MONTH('Calendar'[Date]) = 8, 11,
MONTH('Calendar'[Date]) = 9, 12
)
但不幸的是,我似乎无法找出一个公式来获得财政年度季度号。我最近的尝试是将 SWITCH 函数与 DATESBETWEEN 一起使用,如下所示:
Fiscal YearQuarter No =
SWITCH(
TRUE(),
(DATESBETWEEN('Calendar',MONTH('Calendar'[Date]) >= 9, MONTH('Calendar'[Date])) <= 12)), 1,
(DATESBETWEEN ('Calendar'[Date],MONTH('Calendar'[Date]) >= 1, MONTH('Calendar'[Date]) <= 3)), 2,
(DATESBETWEEN ('Calendar'[Date],MONTH('Calendar'[Date]) >= 4, MONTH('Calendar'[Date]) <= 6)), 3,
(DATESBETWEEN ('Calendar'[Date],MONTH('Calendar'[Date]) >= 7, MONTH('Calendar'[Date]) <= 9)), 4
)
很遗憾,我遇到了语法错误。
由于 MONTH() 函数 returns 是一个整数值,我认为这就是为什么您使用 DATESBETWEEN() 函数包装它时会出现语法错误的原因。
相反,只需使用简单的整数运算符。我用这个计算测试了你的数据,它有效:
Fiscal YearQuarter No =
SWITCH(
TRUE(),
MONTH('Calendar'[Date])>=10 && MONTH('Calendar'[Date]) <= 12,1,
MONTH('Calendar'[Date])>=1 && MONTH('Calendar'[Date]) <= 3,2,
MONTH('Calendar'[Date])>=4 && MONTH('Calendar'[Date]) <= 6,3,
MONTH('Calendar'[Date])>=7 && MONTH('Calendar'[Date]) <= 9,4
)
此外,您可能不需要这么长的表达式来计算您的会计月份数字,因为您的会计日历与标准日历仅相差 3 个月。尝试用一个算术公式来代替它。这应该有效:
Fiscal YearMonth No= =
=IF((MONTH('Calendar'[Date])+3)>12,ABS(12-(MONTH('Calendar'[Date])+3)),(MONTH('Calendar'[Date])+3))
您可以像这样简单地将您的日历年更改为财政年
Fiscal Month = Orders[Order Date].[Month]
Fiscal Year = CONCATENATE("FY ",IF(Orders[Order Date].[MonthNo]>=4 && Orders[Order Date].[MonthNo]<=12,Orders[Order Date].[Year],Orders[Order Date].
[Year]-1))
这个财政年度是根据印度财政年度。