Here, this should do the trick.
MONTH ( TODAY () ) = 1,
DATE ( YEAR ( TODAY () ) - 1, 12, DAY ( TODAY () ) ),
DATE ( YEAR ( TODAY () ), MONTH ( TODAY () ) - 1, DAY ( TODAY () ) )
In my oppinion what @Greg_Deckler proposed does not work correctly because you have to deal with dates like 29 of February, or even sympler what if today is 31st of something but one month ago 31st does not exist. Or what heppens if themonth is January?
I do not have a solution yet but thsi is definately not the answer.
Neither of the proposed solutions works fully due to the effects identified by @tschris i.e. if the previous month doesn't contain the same 'day' value as 'today'. However, in my case, I needed to handle a change of year scenario but wasn't bothered about the actual 'day' value. I just wanted a measure to show the previous month/year in a card visual along the lines of 'January 2019' or 'June 2018' etc. This made it easy for me to still use the code to handle the year change with a little bit of change where the 'day' value is created - I just force it to always be a '1'.
_monthYearTitle = IF ( MONTH ( TODAY () ) = 1, /* YES */ FORMAT( DATE ( YEAR ( TODAY () ) - 1, 12, 1 ),"MMMM YYYY"), /* NO */ FORMAT( DATE ( YEAR ( TODAY () ), MONTH ( TODAY () ) - 1, 1 ), "MMMM YYYY") )
I think the solution below solves the "different number of days in different month" and January issues. The main improvement on @amaclure's solution is taking the minimium of today's day and last month's last day using built in functions.
Previous MTD = VAR start_of_prev_month = EOMONTH(TODAY(),-2) + 1 VAR mtd_prev_month = IF(MONTH(TODAY()) = 1, DATE(YEAR(TODAY())-1, MONTH(12), MIN(DAY(TODAY()), DAY(EOMONTH(start_of_prev_month,0)))), DATE(YEAR(TODAY()), MONTH(TODAY())-1, MIN(DAY(TODAY()), DAY(EOMONTH(start_of_prev_month,0))))) RETURN(CALCULATE(SUM(RET[Trade Quantity]),'Date'[Date] >= start_of_prev_month, 'Date'[Date] <= mtd_prev_month))
Check out new user group experience and if you are a leader please create your group!
On-demand access to all the great content presented by the product teams and community members! #MSBizAppsSummit #CommunityRocks
Mark your calendars and join us for our next Power BI Dev Camp!