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

Announcements
Qlik Connect 2026! Turn data into bold moves, April 13 -15: Learn More!
cancel
Showing results for 
Search instead for 
Did you mean: 
deepakqlikview_123
Specialist
Specialist

Calculating Top N values but excluding rows based on other columns conditions

Hi All,

PFA.

I need to find out Top 5 names based on Num column value but if value in value column is negative I need to skip that row and find out Top 5 names based on num column

For eg-

based on my data my values top 5  based in num col is 10,40,7,6,5 but

40 and 5 has negative vaues assigned in column value that is -5 so i need to skip whole row so that my top 5 values would be

10,2,3,6,7

Can you please suggest how to proceed.

Thanks

5 Replies
vinieme12
Champion III
Champion III

Try

if(Value>0,Rank(Num,1,1))

Or this

AGGR(rank(if(Value>0,Num),1,1),Name)

Vineeth Pujari
If a post helps to resolve your issue, please accept it as a Solution.
tresesco
MVP
MVP

Try like:

Sum({<Name={"=Rank(Sum({<Value={'>=0'}>}Num))<6"}>}Num)

Capture.PNG

deepakqlikview_123
Specialist
Specialist
Author

Hi All,

thanks for the reply,

For top 20 records.

=aggr(if(rank((sum(ForecastReserve) - Sum(ActualReserve)))<=20,[Dim SellRep]),[Dim CustNo])

I need to show only those records where sum(Openamount)>0

Can you please suggest how should i modify the expression.

Thanks

deepakqlikview_123
Specialist
Specialist
Author

Hi All,

thanks for the reply,

For top 20 records.

=aggr(if(rank((sum(ForecastReserve) - Sum(ActualReserve)))<=20,[Dim SellRep]),[Dim CustNo])

I need to show only those records where sum(Openamount)>0

Can you please suggest how should i modify the expression.

Thanks

deepakqlikview_123
Specialist
Specialist
Author

Hi All,

Please find attached sample app.

I need to avoid the aggregation in expresion but rowno() gives performance issues for larger data sets.

Can you please suggest how should i avoid aggregation.

Thanks