data:image/s3,"s3://crabby-images/2b51c/2b51c0b632aa83619721e6c0794d8ee99b77430a" alt=""
A common requirement when reporting data with a Date axis is to be able to see the year and the month in a short form beside each other. Formats such as 2021 Jan, or Jan 2021, or even Jan 21, or 2021-01 are very popular. In Power BI, ideally, you should have a Date dimension with columns for this. However, if you don’t I’ll explain how you can create these formats easily using DAX.
Video
Sample table
My sample table just have a single column; Date as below;
data:image/s3,"s3://crabby-images/6138b/6138b87ba73994d80d0e092d4231c2959a4b8230" alt=""
Label column
If you are going to use the month NAME as part of the year-month combination, then you will need a label column and a code column. The label column is used to show the year-month combination in the visual, and the code column to sort the label column. let’s start with the label column;
To create a column for the year and month combined, one of the most helpful functions will be the FORMAT function. You can use the Format function like below;
Year-Month = FORMAT('Date'[Date],"YYYY MMM")
This can be a calculated column added to your table;
data:image/s3,"s3://crabby-images/016d9/016d972aecf7c010adb2e0aa06fee49d8e1aac61" alt=""
The output will be in the format of four digits for the year, and then a three-character month name after a space. That is because we used YYYY MMM as the format expression. You can use formats as below too;
data:image/s3,"s3://crabby-images/95d8a/95d8a9b1fabbb696498ff27d9b4b8af321165ff5" alt=""
Note that the M and Y can be lowercase too. Here is what they mean;
Character | Details | Sample |
---|---|---|
MMMM | full month name | January |
MMM | three-characters month name | Jan |
MM | two-digit month number | 01 |
M | One or two-digits month number (no leading zero) | 1 |
YYYY | 4-digit year number | 2020 |
YY | 2-digit year number | 20 |
Code column
This column above by itself usually isn’t enough, as the order of items might not be the right order if you used a format that produces the month name instead of the number. You would need a column that is The Year-Month code and you can use that to sort the Year-Month column.
This code generates a six-digit text for year and month combined which will be always in the right order if converted to a number;
Year-Month Code = FORMAT('Date'[Date],"YYYYMM")
data:image/s3,"s3://crabby-images/4c5d3/4c5d37980f930a1c1a64e0e3a0440536b5d30c04" alt=""
Sort by Column
It doesn’t matter what format you used for the label column, the code column can sort it, by using the Sort by Column option. I explained more about this feature here in this article.
data:image/s3,"s3://crabby-images/8b1a4/8b1a46d46cab5a8a3c877cdbe2194ac5eab7c1cc" alt=""
And this gives me the right ordered list of year-month values as below in any visual;
data:image/s3,"s3://crabby-images/8446a/8446a7074b4692eda76619e22c55f3a519dd5082" alt=""
Hide the code column
Note that, it is recommended to hide the Year-Month code column from the report view. To learn more about what columns are a good candidate to be hidden read my article here.
data:image/s3,"s3://crabby-images/45211/452115f21a0da410fd751d0884fece9e9fcb0bb1" alt=""
Date Dimension
I strongly suggest using a Date dimension (or calendar table) including all the columns for slicing and dicing by date-related attributes. A full script of a date dimension is available here in this article for you available to download;
Thanks for this awesome solution – easy to set up
Thank you, that was easy to follow and solved my problem.
Thanks. I am glad it helped.
This is amazing, thanks for sharing
Thanks. I am glad to help
Thank you so much. Best Solution!