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

Join us for an expert-led overview of the tools and concepts you'll need to become a Certified Power BI Data Analyst and pass exam PL-300. Register now.

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
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 Power BI Update Carousel

Power BI Monthly Update - June 2025

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

June 2025 community update carousel

Fabric Community Update - June 2025

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