美文网首页商业智能BI那点事儿Power BI干货PowerBI专栏
Power BI应用:如何用DAX计算在职人数?

Power BI应用:如何用DAX计算在职人数?

作者: PowerBI星球 | 来源:发表于2020-04-28 20:51 被阅读0次

    ​经常碰到的一类问题是,如何根据起止日期来计算某个时间点的数量,比如:

    已知合同的生效日期和到期日期,特定日期的有效合同有多少?

    已知店铺的开业日期和注销日期,截至目前正在运营的店铺有多少?

    已知员工的入职日期和离职日期,如何计算每个月底的在职员工数量?

    此类问题的解决思路类似,下面就以计算在职员工数量为例,看看如何利用PowerBI来处理。

    模拟数据如下,员工表中有员工姓名、入职日期和离职日期:

    实现步骤如下:

    1,建立数据模型

    因为要按时间点计算,所以建立一个单独的日期表是必要的。

    这里有同学会纠结,员工表中有两列日期,那么应该用哪个日期与日期表建立关系呢?

    这个看具体需求,就这个问题来说,完全可以不建立任何关系:

    2,创建度量值

    根据员工表,统计员工数量的逻辑很简单,比如计算6月30号的在职员工数量,就是入职日期小于等于6月30日,并且没有离职或者离职日期大于6月30日的所有员工。

    在度量值中,还应该考虑的是上下文是什么,因为我们是想求每个月底的数量,所以外部上下文就是月份,根据这个月份,找出该月最后一天,然后根据上面的逻辑比较就行了。

    这样的计算逻辑每个人都清楚,但是可能不知道如何用DAX来表达。

    度量值的写法如下:

    以上思路和计算逻辑都已体现在这个度量值中,并在代码中做了注释。

    3,展示计算结果

    将日期表中的月份和[在职员工数量]放入到矩阵中,就得出了每月底的员工数量:

    更进一步的,如果想计算某个时间段的平均每天在职人数,只需要在上述度量值的基础上,再写个平均度量值:

    平均在职人数 = 

    AVERAGEX(

        VALUES('日期表'[日期]),

        [在职员工数量]

    )

    用日期做个切片器,输入时间段的起止日期,就可以快速计算出该时间段的平均每天人数:

    使用PowerBI解决问题的基本就是以上的步骤,把这个简单的例子搞明白了,这一类问题都会迎刃而解。

    -精彩推荐-

    PDF转Excel,这个秘籍推荐给你

    利用PowerBI移动平均来进行准确预测

    体验PowerBI:零基础制作一个可视化报表

    如果你刚开始学习Power BI,可在微信公众号后台回复"PowerBI",获取《七天入门PowerBI》电子书,轻松上手。

    采悟  @ PowerBI星球

    相关文章

      网友评论

        本文标题:Power BI应用:如何用DAX计算在职人数?

        本文链接:https://www.haomeiwen.com/subject/bztiwhtx.html