Earn the coveted Fabric Analytics Engineer certification. 100% off your exam for a limited time only!
Dear All,
I have a database that contains the date, the activity name and the minutes that activity lasted:
Activity_StartTime | Activity_Name | Activity_Duration_Minutes |
09/08/2016 15:01 | Activity 1 | 45 |
09/08/2016 15:01 | Activity 1 | 45 |
10/08/2016 16:46 | Activity 1 | 30 |
10/08/2016 16:46 | Activity 1 | 30 |
10/08/2016 16:46 | Activity 1 | 30 |
11/08/2016 19:00 | Activity 1 | 20 |
11/08/2016 19:00 | Activity 1 | 20 |
I would need a bar chart.
On the X axes I would like to have the year and
on the Y axes I would need the number of minutes of the activity.
In this case the hight of the bar should be 45+30+20=95
Thank you for picking up this challenge.
Solved! Go to Solution.
Hi, welcome to the community. This solution assumes that there is no other data being used and that all activities have a different start time
1. Make a new calculated column called year to use for the x axis. in it put the DAX =year(Activity_StartTime)
2. Make a second calculated column with the DAX =divide(calculate(average(Table1[Activity_Duration_Minutes]),ALLEXCEPT(Table1,Table1[Activity_StartTime],Table1[Activity_Name])),calculate(COUNTA(Table1[Activity_StartTime]),ALLEXCEPT(Table1,Table1[Activity_StartTime],Table1[Activity_Name])),0)
3. Use the calculated column as the value in the stacked chart
// please mark as solution if it answers your question.
Hi, i have formatted the DAX a little better for you:
=
DIVIDE (
CALCULATE (
AVERAGE ( Table1[Activity_Duration_Minutes] ),
ALLEXCEPT ( Table1, Table1[Activity_StartTime], Table1[Activity_Name] )
),
CALCULATE (
COUNTA ( Table1[Activity_StartTime] ),
ALLEXCEPT ( Table1, Table1[Activity_StartTime], Table1[Activity_Name] )
),
0
)
its working it out by gouping together the numbers that share the same activity name and the same start time and dividing them by the count of how many in each group eg: average(45,45)/count(45,45) = 2 * 22.5; average(30,30,30)/count(30,30,30) = 3 * 10; average(20,20)/count(20,20) = 2 * 10. When you add that to your chart it will sum up the individual calculations.
Hi, welcome to the community. This solution assumes that there is no other data being used and that all activities have a different start time
1. Make a new calculated column called year to use for the x axis. in it put the DAX =year(Activity_StartTime)
2. Make a second calculated column with the DAX =divide(calculate(average(Table1[Activity_Duration_Minutes]),ALLEXCEPT(Table1,Table1[Activity_StartTime],Table1[Activity_Name])),calculate(COUNTA(Table1[Activity_StartTime]),ALLEXCEPT(Table1,Table1[Activity_StartTime],Table1[Activity_Name])),0)
3. Use the calculated column as the value in the stacked chart
// please mark as solution if it answers your question.
Thank you, it is working as expected.
Best regards,
Nandor
Hi, Thank you again for the solution. I am struggling to understand the formula, could you please explaint the logics behind your script.
Thank you,
Nandor
Hi, i have formatted the DAX a little better for you:
=
DIVIDE (
CALCULATE (
AVERAGE ( Table1[Activity_Duration_Minutes] ),
ALLEXCEPT ( Table1, Table1[Activity_StartTime], Table1[Activity_Name] )
),
CALCULATE (
COUNTA ( Table1[Activity_StartTime] ),
ALLEXCEPT ( Table1, Table1[Activity_StartTime], Table1[Activity_Name] )
),
0
)
its working it out by gouping together the numbers that share the same activity name and the same start time and dividing them by the count of how many in each group eg: average(45,45)/count(45,45) = 2 * 22.5; average(30,30,30)/count(30,30,30) = 3 * 10; average(20,20)/count(20,20) = 2 * 10. When you add that to your chart it will sum up the individual calculations.
Thank you!
User | Count |
---|---|
140 | |
113 | |
104 | |
77 | |
65 |
User | Count |
---|---|
135 | |
116 | |
101 | |
71 | |
61 |