I am trying to keep the maximum observations for each ID by Var1 while keeping duplicates for the max. I have data such as:
ID Var1 Var2
1 90 8
1 90 9
1 85 8
2 70 6
2 70 5
2 65 9
3 50 5
3 65 5
and I want the following data:
ID Var1 Var2
1 90 8
1 90 9
2 70 6
2 70 5
3 65 5
I have tried a couple of different methods but have not had any sucess so far.
Here is one way:
proc sql noprint;
create table want as
select *
from have
group by ID
having Var1 eq max(Var1)
;
quit;
Art, CEO, AnalystFinder.com
Here is one way:
proc sql noprint;
create table want as
select *
from have
group by ID
having Var1 eq max(Var1)
;
quit;
Art, CEO, AnalystFinder.com
Thank you, that appears to work correctly
April 27 – 30 | Gaylord Texan | Grapevine, Texas
Walk in ready to learn. Walk out ready to deliver. This is the data and AI conference you can't afford to miss.
Register now and lock in 2025 pricing—just $495!
Still thinking about your presentation idea? The submission deadline has been extended to Friday, Nov. 14, at 11:59 p.m. ET.
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.
Ready to level-up your skills? Choose your own adventure.