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

Register now to learn Fabric in free live sessions led by the best Microsoft experts. From Apr 16 to May 9, in English and Spanish.

Reply
Anonymous
Not applicable

Create a Calculated COlumn based on Slicer from a different table

I have created a SlicerTable with DateRange column having values  - YearToDate and Rolling12Months.

In my main Table I have 24 months of data and a datefield "ReportingDate" which I want to filter into Current year and Previous Year.

 

This means, when I select "YearToDate" in Slicer then I should have value as below

DateField           ClaculatedColumn

01/10/2020         CurrentYear

02/01/2020         CurrentYear

01/10/2019         PreviousYear

 

Can anyone suggest how can I achieve this. Thanks for the help/

02/01/2019         PreviousYear

 

 

1 ACCEPTED SOLUTION
v-gizhi-msft
Community Support
Community Support

Hi,

 

According to your description, i create a sample to test:

10.PNG

Then create a slicer table:

Date SLicer = DISTINCT(SELECTCOLUMNS('Table',"Year",'Table'[DateField].[Year])) 

For your requirement, i think you can not use calculated column to achieve the result as you posted because calculated column can not be changed dynamically by selecting value in slicer.

So i advise using measure, please try this:

Measure = IF(YEAR(MAX('Table'[DateField]))=SELECTEDVALUE('Date SLicer'[Year]),"Current Year",IF(YEAR(MAX('Table'[DateField]))=SELECTEDVALUE('Date SLicer'[Year])-1,"Previous Year",BLANK()))

When you select one year in slicer, the result shows:

11.PNG

Here is my test pbix file:

pbix 

Hope this helps.

 

Best Regards,

Giotto Zhi

View solution in original post

2 REPLIES 2
v-gizhi-msft
Community Support
Community Support

Hi,

 

According to your description, i create a sample to test:

10.PNG

Then create a slicer table:

Date SLicer = DISTINCT(SELECTCOLUMNS('Table',"Year",'Table'[DateField].[Year])) 

For your requirement, i think you can not use calculated column to achieve the result as you posted because calculated column can not be changed dynamically by selecting value in slicer.

So i advise using measure, please try this:

Measure = IF(YEAR(MAX('Table'[DateField]))=SELECTEDVALUE('Date SLicer'[Year]),"Current Year",IF(YEAR(MAX('Table'[DateField]))=SELECTEDVALUE('Date SLicer'[Year])-1,"Previous Year",BLANK()))

When you select one year in slicer, the result shows:

11.PNG

Here is my test pbix file:

pbix 

Hope this helps.

 

Best Regards,

Giotto Zhi

Greg_Deckler
Super User
Super User

You would need a measure to do that I think. Please see this post regarding How to Get Your Question Answered Quickly: https://community.powerbi.com/t5/Community-Blog/How-to-Get-Your-Question-Answered-Quickly/ba-p/38490


@ me in replies or I'll lose your thread!!!
Instead of a Kudo, please vote for this idea
Become an expert!: Enterprise DNA
External Tools: MSHGQM
YouTube Channel!: Microsoft Hates Greg
Latest book!:
The Definitive Guide to Power Query (M)

DAX is easy, CALCULATE makes DAX hard...

Helpful resources

Announcements
Microsoft Fabric Learn Together

Microsoft Fabric Learn Together

Covering the world! 9:00-10:30 AM Sydney, 4:00-5:30 PM CET (Paris/Berlin), 7:00-8:30 PM Mexico City

PBI_APRIL_CAROUSEL1

Power BI Monthly Update - April 2024

Check out the April 2024 Power BI update to learn about new features.

April Fabric Community Update

Fabric Community Update - April 2024

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