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

Don't miss out! 2025 Microsoft Fabric Community Conference, March 31 - April 2, Las Vegas, Nevada. Use code MSCUST for a $150 discount. Prices go up February 11th. Register now.

Reply
NBOnecall
Helper V
Helper V

Average Value based on Min and Max of a date slicer

Hi,

 

I have a data set that looks like below. I have Inventory value for each day inventory is available. If inventory is not available it does not populate the data set. For example there is no data for 2/7/19, 2/8/19 or 2/19/19. I would like to calculate the Average Value Based on a slicer deteremined by the min and max date choosen. It takes that value at the min and max adds them together and divides by 2. Needs to be calculated based of InternalID and LocationID.

 

Data.PNG

The one issue that I can see is if I choose a date without a value there that it defaults to 0 for that value. See expected results below.

 

Expected Value.PNG

Thank you for taking a look!

2 ACCEPTED SOLUTIONS

Ahh, I think I was trying to be too clever, using an AVERAGEA expression. The problem is that the filter is catching the date with blank data before it even gets to the AVERAGEA part, so it isn't counted in the average.  You could get around this by using LEFTJOINS instead of straight filters, but that sounds like a headache.

 

Instead, you can set this up as your own manual average:

 

AvgValue = 
VAR avg = CALCULATE( SUM(DataTable[Value])/2, FILTER(DataTable, DataTable[Inventory Date] = MAX(DateTable[Date]) || MIN(DateTable[Date]) ))
RETURN
IF(avg = 0, BLANK(), avg)

 

View solution in original post

After your help and some more searching on the forum I ended up going with the following lines of code.

MinValue = 
VAR Min1 = CALCULATE( SUM('ns InventorySnapshot'[Value]), FILTER('ns InventorySnapshot', 'ns InventorySnapshot'[InventoryDate] = MIN(Dimtime[Date]) ))
return
IF(ISBLANK(Min1), 0, Min1)
MaxValue = 
VAR Max1 = CALCULATE( SUM('ns InventorySnapshot'[Value]), FILTER('ns InventorySnapshot', 'ns InventorySnapshot'[InventoryDate] = MAX(Dimtime[Date]) ))
return
IF(ISBLANK(max1), 0, Max1)
AvgValue2 = ([MinValue]+[MaxValue])/2

Yes it is a couple more measures, but it gets my desired results.

View solution in original post

6 REPLIES 6
NBOnecall
Helper V
Helper V

Anyone have any ideas on how to fix this?

Cmcmahan
Resident Rockstar
Resident Rockstar

So it looks like in your list of expected outcomes, you WANT to treat blanks in your data as zeroes.  You don't want to use the values in between, you just want to take the mathematical average of the value on MIN([InventoryDate]) and MAX([InventoryDate]).  If there's a blank on one of the days, treat as a zero, but if there's a blank on both days, return a blank instead.

Your measure would look like this:

AvgValue = 
VAR avg = CALCULATE( AVERAGEA(DataTable[Value]), FILTER(DataTable, DataTable[Inventory Date] = MAX(DateTable[Date]) || MIN(DateTable[Date]) ))
RETURN
IF(avg = 0, BLANK(), avg)

It's important here that your slicer be running off a date dimension that's related to your data, because MAX(DataTable[Inventory Date]) will just give the max available date that's allowed by the slicer.  A date dimension will have the blank dates available.

Ahh, I think I was trying to be too clever, using an AVERAGEA expression. The problem is that the filter is catching the date with blank data before it even gets to the AVERAGEA part, so it isn't counted in the average.  You could get around this by using LEFTJOINS instead of straight filters, but that sounds like a headache.

 

Instead, you can set this up as your own manual average:

 

AvgValue = 
VAR avg = CALCULATE( SUM(DataTable[Value])/2, FILTER(DataTable, DataTable[Inventory Date] = MAX(DateTable[Date]) || MIN(DateTable[Date]) ))
RETURN
IF(avg = 0, BLANK(), avg)

 

After your help and some more searching on the forum I ended up going with the following lines of code.

MinValue = 
VAR Min1 = CALCULATE( SUM('ns InventorySnapshot'[Value]), FILTER('ns InventorySnapshot', 'ns InventorySnapshot'[InventoryDate] = MIN(Dimtime[Date]) ))
return
IF(ISBLANK(Min1), 0, Min1)
MaxValue = 
VAR Max1 = CALCULATE( SUM('ns InventorySnapshot'[Value]), FILTER('ns InventorySnapshot', 'ns InventorySnapshot'[InventoryDate] = MAX(Dimtime[Date]) ))
return
IF(ISBLANK(max1), 0, Max1)
AvgValue2 = ([MinValue]+[MaxValue])/2

Yes it is a couple more measures, but it gets my desired results.

Yup! That's exactly what the second version is doing, except in one step instead of as multiple measures.  Always multiple ways to skin the cat in Power BI. Glad you got it figured out!

Thank you, for the most part this is exactly what I need, but it is having issues with dates no in the data set that need to be 0, and it might have been from not having a little bit more data in the original data. To start here is the relationship of the dimtime table.

Relationship.PNG

 

Second is the data for this specific item, I am basing this on the hand number for the value. So if nothing is OnHand, but on order a line will be available, but it would be a $0 value. I still have cases where there is no data at all for the dates.

Wrong Results.png

 

Here is the result of going between Feb 26th ($598.77) and the 28th ($0). It should be $299.385. Any thoughts?

Item9385.PNG

 

Thanks!

Helpful resources

Announcements
Las Vegas 2025

Join us at the Microsoft Fabric Community Conference

March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!

Jan25PBI_Carousel

Power BI Monthly Update - January 2025

Check out the January 2025 Power BI update to learn about new features in Reporting, Modeling, and Data Connectivity.

Jan NL Carousel

Fabric Community Update - January 2025

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