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

Data structure:

PriceTheMonthTheYear
1012013
1112013
1512012
1222013
1322012

I am struggling to compute max value of Price variable for each combination of TheMonth and TheYear

Final Result Expected:

PriceTheMonthTheYear
1112013
1512012
1222013
1322012

I believe I cannot use MAX() function directly as it is not possible to define the array.

Will DO statement resolve it? in conjunction with BY statement after data is sorted by TheYear and TheMonth; sort of hazy on how to hash out the logic

Appreciate the feedback.

Thankfully,

Dhanashree Gadkari

1 ACCEPTED SOLUTION

Accepted Solutions
esjackso
Quartz | Level 8

Another alternative would be to use group by in SQL:

Proc sql;

     create table max as

     select max(price) as Mprice, themonth, theyear

     from yourdata

     group by themonth, theyear

;

quit;

If you dont need a dataset you can leave the table statement off and the report will output.

EJ

View solution in original post

6 REPLIES 6
Rick_SAS
SAS Super FREQ

The simplest way is to bypass the DATA step and use PROC MEANS:

proc means data=... max;

class TheMonth TheYear;

var Price;

run;

Ksharp
Super User

there is need a option:

proc means nway ;

or use BY instead of CLASS.

Ksharp

Rick_SAS
SAS Super FREQ

The NWAY option only affects an output data set.  For printed output, it doesn't matter:

proc means data=sashelp.cars max  /* NWAY */;

class origin type;

var mpg_city;

run;

esjackso
Quartz | Level 8

Another alternative would be to use group by in SQL:

Proc sql;

     create table max as

     select max(price) as Mprice, themonth, theyear

     from yourdata

     group by themonth, theyear

;

quit;

If you dont need a dataset you can leave the table statement off and the report will output.

EJ

noobs
Fluorite | Level 6

That was it. You resolved it esjackso1 thanks a bunch.

noobs
Fluorite | Level 6

Although the output of your suggestion is what I am exactly looking for, I need to restore data structure of output statistics as shown in Final data structure above for further plotting bubble charts  .

So do you suggest using OUTPUT statement in proc MEANS, to capture Price, TheYear, TheMonth?

Not sure how to delete unwanted columns like _TYPE_ _FREQ_ and keep only MAX stat in proc step

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
  • 6 replies
  • 1866 views
  • 0 likes
  • 4 in conversation