Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Enhance your career with this limited time 50% discount on Fabric and Power BI exams. Ends August 31st. Request your voucher.

Reply
abbytank
Frequent Visitor

calculate and sameperiodlastyear not working IF function

Hi, 
I am having issue with the following calculation, I want to calculate the total sales, which is working correct, but when I select a year whose previous year had no sales like the initial year, it show blank, I needed to use if to avoid showing blank, but it returned error. Here is the code:
Previous_year_sales = if(ISBLANK(SAMEPERIODLASTYEAR('Date'[Date])),

"No Sales",

CALCULATE([TotalSales],

        SAMEPERIODLASTYEAR('Date'[Date]))
)
Please someone help.
 
Thank you in advance.
 
1 ACCEPTED SOLUTION
Anonymous
Not applicable

Hi @abbytank ,

Actually, the function ISBLANK is to check whether a value is blank. But it will return a table when you apply the function SAMEPERIODLASTYEAR. You can find the details in the following links.

ISBLANK

SAMEPERIODLASTYEAR

Best Regards

View solution in original post

3 REPLIES 3
Anonymous
Not applicable

Hi @abbytank ,

You can update the formula of measure [Previous_year_sales] as below, please notice that the data type of returned result will be Text type instead of Number type. If you still want to keep the data type as Number type, you can change "No Sales" to 0.

Previous_year_sales =
VAR _pysales =
    CALCULATE ( [TotalSales], SAMEPERIODLASTYEAR ( 'Date'[Date] ) )
RETURN
    IF ( ISBLANK ( _pysales ), "No Sales", _pysales )

yingyinr_0-1670901130132.png

 

If the above one can't help you get the desired result, please provide some sample data in your tables (exclude sensitive data) with Text format and your expected result with backend logic and special examples. It is better if you can share a simplified pbix file. You can refer the following link to upload the file to the community. Thank you.

How to upload PBI in Community

Best Regards

Thank you very much @Anonymous  for your supportive response.

 

I see your solutions is 100% working and providing the very desired result, but concern is:

This is working:

VAR _pysales =
    CALCULATE ( [TotalSales], SAMEPERIODLASTYEAR ( 'Date'[Date] ) )
return _pysales

And also, the following is working:

ISBLANK(SAMEPERIODLASTYEAR('Date'[Date]))

And even the first the part of the code is working, because when the previous years sales is empty (no sales on previous year) the result is working and showing "No Sales" result:

Previous_year_sales = if(ISBLANK(SAMEPERIODLASTYEAR('Date'[Date])),

"No Sales",

 

But the problem is, when the calculate function or even sumx function put on the IF functions as (if function's) return values (return values on true or false) according to the following:

Previous_year_sales = if(ISBLANK(SAMEPERIODLASTYEAR('Date'[Date])),

"No Sales",

CALCULATE([TotalSales],

        SAMEPERIODLASTYEAR('Date'[Date]))
)

So, why calculate is not working in IF function's argument, that is my concern?

 

Thank you very much.

Anonymous
Not applicable

Hi @abbytank ,

Actually, the function ISBLANK is to check whether a value is blank. But it will return a table when you apply the function SAMEPERIODLASTYEAR. You can find the details in the following links.

ISBLANK

SAMEPERIODLASTYEAR

Best Regards

Helpful resources

Announcements
July PBI25 Carousel

Power BI Monthly Update - July 2025

Check out the July 2025 Power BI update to learn about new features.

Join our Fabric User Panel

Join our Fabric User Panel

This is your chance to engage directly with the engineering team behind Fabric and Power BI. Share your experiences and shape the future.

June 2025 community update carousel

Fabric Community Update - June 2025

Find out what's new and trending in the Fabric community.