FIRSTDATE, LASTDATE
FIRSTDATE returns first non blank date LASTDATE returns last non blank date.
Example
I want to calculate first 15 days of the sale.
FIRST 15 DAYS SALE =
VAR _START = DATE (2021, 01, 01)
VAR _END = DATE (2021, 01, 15)
VAR _RESULT =
CALCULATE (SUM ( tblSales[Sales] ),
FILTER (tblSales,
(
FIRSTDATE ( tblSales[Date] ) >= _START
&& LASTDATE ( tblSales[Date] ) <= _END
)
))
RETURN _RESULT
data:image/s3,"s3://crabby-images/333f0/333f081d4f2cc693ac428ff00718d05cbe5dae1a" alt=""
NOTE: You can use this measure, to calculate the running total for the first 15 days
FIRST 15 DAYS CUM_SALE =
VAR Period =
DATESBETWEEN ( tblSales[Date], DATE (2021, 01, 01), DATE (2021, 1, 15))
VAR _RESULT =CALCULATE (SUM ( tblSales[Sales] ),
DATESYTD ( tblSales[Date], "2021-01-15"), Period)
RETURN _RESULT
data:image/s3,"s3://crabby-images/30999/309999d11df2a4dc867add18f8d7a8a9b579db4c" alt=""
Example
step 1 > create 2 measure, FistDateSale & LastDateSale
_FirstDateSale = CALCULATE([Total Sales],FIRSTDATE(tblSales[Date]))
_LastDateSale = CALCULATE([Total Sales],LASTDATE(tblSales[Date]))
measure for the Total Sales is as follow:
Total Sales = CALCULATE(SUM(tblSales[Sales]),DATESMTD(tblSales[Date]))
This measure is calculating the running total in the month.
You can use the measures in the summarized table. This table is grouped be Year_month column.
data:image/s3,"s3://crabby-images/49406/494064f04e2b2361bd549817392222d556d4583f" alt=""
FIRSTNONBLANK, LASTNONBLANK
FIRSTNONBLANK: returns the first value in the column for which the expression has a non blank value.
LASTNONBLANK: returns the last value in the column for which the expression has a non blank value.
syntax:
FIRSTNONBLANK(<column>,<expression>)
LASTNONBLANK(<column>,<expression>)
Example
I want to retrieve specified date from the table.
data:image/s3,"s3://crabby-images/d0244/d024422d74d6ee144610ef034e60a42251b3f8a1" alt=""
Example
I want to create a measure which will contain the sum of occurrences of values in Column A based on the values in Column B.
NUMBER OF OCCURRENCES =
VAR COL_B =
FIRSTNONBLANK ( LETTERS[Column B], "")
VAR RESULT =
CALCULATE (COUNTROWS ( LETTERS ), ALL (), LETTERS[Column A ] = COL_B)
RETURN
IF (ISBLANK (RESULT), 0, RESULT)
data:image/s3,"s3://crabby-images/1f890/1f8906a14650e0c0f59187c201d6717f8d4357c7" alt=""
NEXTDAY,NEXTMONTH,NEXTQUARTER,NEXTYEAR
NEXTDAY () is similar to DATEADD()
syntax
NEXTDAY(<dates>)
_NextDay = CALCULATE([Total Sales],NEXTDAY(tblSales[Date]))
_NextDay 2 = CALCULATE([Total Sales],DATEADD(tblSales[Date],1,DAY))
data:image/s3,"s3://crabby-images/dfa79/dfa79cb2868280504fb7bef20f97a71522c43912" alt=""
NEXTMONTH
Returns a next month
NEXTMONTH(<dates>)
data:image/s3,"s3://crabby-images/918d2/918d26d9fa4849c4aa607236b50f942c111428db" alt=""
NEXTYEAR
Returns a table that contains a column of all dates in the next year, based on the first date in the dates column, in the current context.
NEXTYEAR(<dates>[,<year_end_date>])
NEXTYEAR() function returned the sum for the next year 2022 (102+75+46 = 223)
data:image/s3,"s3://crabby-images/1d1b7/1d1b7dd06f5176e39ea7dd6c85d6afeb48ec8676" alt=""
_NEXTYEAR =
CALCULATE(SUM(tblSales[Sales]), NEXTYEAR(tblSales[Date],"2021-01-31"))
[,<year_end_date>] is an optional argument, you can use it for the fiscal year calculation.
data:image/s3,"s3://crabby-images/f4237/f42374947ac632969408e68812c2fb13e4e4f604" alt=""
PARALLELPERIOD
Returns a parallel period of dates by the given set of dates and a specified interval.
PARALLELPERIOD returns a full period shifted in time.
PARALLELPERIOD(<dates>,<number_of_intervals>,<interval>)
<interval> month, quarter, year
data:image/s3,"s3://crabby-images/daab0/daab02a2fa04da0f69807c3ccd7106ae44ad0c05" alt=""
Example
This picture demonstrate a difference between two different entries in the PARALLELPERIOD () function. <-12,MONTH> will shift the dates, <-1,YAER> returns a grand total for each row.
data:image/s3,"s3://crabby-images/291ea/291ea96ec7ffd4a19f5f166989c6bd4c98189caf" alt=""
SAMEPERIODLASTYEAR
Returns a set of dates in the current selection from the previous year.
syntax
SAMEPERIODLASTYEAR(<dates>)
This function is similar to DATEADD(OrdersDate[Date],-1,YEAR)) or PARALLELPERIOD(OrdersDate[Date],-12,MONTH)).
Example
data:image/s3,"s3://crabby-images/83db2/83db2cdd87f7ef544cd734740ed20298e1177e2d" alt=""
Example
Calculating Year over year percentage growth
ORDERS YOY % GROWTH =
VAR ORDERSPRIORYEAR =
CALCULATE ( [ORDERSTOTAL], SAMEPERIODLASTYEAR ( OrdersDate[Date] ))
VAR YOY =
DIVIDE ( ( [ORDERSTOTAL] - ORDERSPRIORYEAR), ORDERSPRIORYEAR)
RETURN YOY
data:image/s3,"s3://crabby-images/d5475/d547552ab3b315681420255db1bf9421853b9403" alt=""
Comments