BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
Sotarkadin
Calcite | Level 5

good Day, 

 

I currently have a SAS create table proc where I do count of how many times a certain value occurs based on another value.  

 

For example in the data below there is a count for how many times the field value occured within the field.  For field AB123 the value Note 1 appeared 100 times in teh database and etc.  I want to pull the top 3 values for each field.  Based on the table below for AB123 i should get the data for the values of Note 1, Note 2 and Note 3.  I hope this makes sense.

 

Field field_value cnt_val
AB123 Note 1 100
AB123 Note 2 90
AB123 Note 3 46
AB123 Note 4 23
AB123 Note 5 12
AB123 Note 6 10
AB123 Note 7 5
BC234 Note 1 1065
BC234 Note 2 456
BC234 Note 3 231
BC234 Note 4 153
BC234 Note 5 100
BC234 Note 6 56
1 ACCEPTED SOLUTION

Accepted Solutions
novinosrin
Tourmaline | Level 20

data have;
input Field $	field_value & $	cnt_val;
cards;
AB123	Note 1	100
AB123	Note 2	90
AB123	Note 3	46
AB123	Note 4	23
AB123	Note 5	12
AB123	Note 6	10
AB123	Note 7	5
BC234	Note 1	1065
BC234	Note 2	456
BC234	Note 3	231
BC234	Note 4	153
BC234	Note 5	100
BC234	Note 6	56
;

proc rank data=have out=want(where=(cnt_val_rank<=3)) ties=low descending;
   by field notsorted;
   var cnt_val ;
   ranks cnt_val_rank ;
run;

View solution in original post

5 REPLIES 5
Astounding
PROC Star

What if there is a five-way tie for third place.  What do you want to do with the 5 tied observations?

Sotarkadin
Calcite | Level 5

If there is a tie I would like just the first one of the ties.

novinosrin
Tourmaline | Level 20

data have;
input Field $	field_value & $	cnt_val;
cards;
AB123	Note 1	100
AB123	Note 2	90
AB123	Note 3	46
AB123	Note 4	23
AB123	Note 5	12
AB123	Note 6	10
AB123	Note 7	5
BC234	Note 1	1065
BC234	Note 2	456
BC234	Note 3	231
BC234	Note 4	153
BC234	Note 5	100
BC234	Note 6	56
;

proc rank data=have out=want(where=(cnt_val_rank<=3)) ties=low descending;
   by field notsorted;
   var cnt_val ;
   ranks cnt_val_rank ;
run;
novinosrin
Tourmaline | Level 20

or just

 

proc sort data=have;
by field descending cnt_val; 
run;

data want;
do _n_=1 by 1 until( last.field);
set have;
by field ;
if _n_<=3 then output;
end;
run;
Sotarkadin
Calcite | Level 5

@novinosrin Thank you so much.  This worked perfectly.  I was trying to use the Rank function and was unable to get it to work properly.

 

 

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

How to Concatenate Values

Learn how use the CAT functions in SAS to join values from multiple variables into a single value.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 5 replies
  • 1576 views
  • 1 like
  • 3 in conversation