Do not input private or sensitive data. View Qlik Privacy & Cookie Policy.
Skip to main content

Announcements
AWS Degraded - You may experience Community slowness, timeouts, or trouble accessing: LATEST HERE
cancel
Showing results for 
Search instead for 
Did you mean: 
hopkinsc
Partner - Specialist III
Partner - Specialist III

Help with Average but ignore zero

Hi all,

I have some expressions that give sales by year. i have some years that are zero and i am trying to ignore those zeros when using avg().

example..

item 123 has sales in 2013, 2015, 2016 and 2017 but no sales in 2014 and 2018

i have a straight table that has the last 5 years sales (so i am not including 2013).

Capture.JPG

The AVG() is taking the full sales values (including 2013) and averaging it across all years, but what i actually want it to do is to only sum the years with values that i have in the chart (2015, 2016, 2017) and divide that total by 3 (as only 3 of the years have values)

so in this example i am trying to get 366.6

Can anyone help?

sample attached.

1 Solution

Accepted Solutions
sunny_talwar

May be this

Sum({<Year={$(=Max(Year)), $(=Max(Year)-1), $(=Max(Year)-2), $(=Max(Year)-3), $(=Max(Year)-4)}>}sales)/

Count(DISTINCT {<sales = {">0"}, Year={$(=Max(Year)), $(=Max(Year)-1), $(=Max(Year)-2), $(=Max(Year)-3), $(=Max(Year)-4)}>} Year)

or this

Avg({<Year={$(=Max(Year)), $(=Max(Year)-1), $(=Max(Year)-2), $(=Max(Year)-3), $(=Max(Year)-4)}, sales = {">0"}>}sales)

View solution in original post

3 Replies
sunny_talwar

May be this

Sum({<Year={$(=Max(Year)), $(=Max(Year)-1), $(=Max(Year)-2), $(=Max(Year)-3), $(=Max(Year)-4)}>}sales)/

Count(DISTINCT {<sales = {">0"}, Year={$(=Max(Year)), $(=Max(Year)-1), $(=Max(Year)-2), $(=Max(Year)-3), $(=Max(Year)-4)}>} Year)

or this

Avg({<Year={$(=Max(Year)), $(=Max(Year)-1), $(=Max(Year)-2), $(=Max(Year)-3), $(=Max(Year)-4)}, sales = {">0"}>}sales)

vitaliichupryna
Creator III
Creator III

Hi Chris,

The following expression also should works:

Avg({<Year = {">=$(=max(Year)-4)"}, sales = {">0"}>}sales)

Thanks,

Vitalii

hopkinsc
Partner - Specialist III
Partner - Specialist III
Author

Thats great, thanks Sunny, i have used the first solution you gave. the second one gave different results in my real data to the first for some reason.

Thanks for your help.