SAS Examples: Proc Freq
Last updated:- Sample data
- Simplest possible proc freq
- Save output to another table
- Show missing data separately
- Proc freq with histogram
- Histogram with continuous data
- Two-way histogram
- Two-way histogram with continuous data
Download the source file here
Sample data
data mytable;
input id= name=$12. balance= state=$2.;
DATALINES;
id=1 name=alice balance=5.12 state=NE
id=2 name=bob balance=12.31 state=SC
id=3 name=charlie balance=45.14 state=NY
id=4 name=daniel balance=32.78 state=
id=5 name=alice balance=20.23 state=WA
id=6 name=bob balance=70.89 state=NM
id=7 name=gabe balance=29.67 state=NM
id=8 name=charlie balance=55.66 state=CA
id=9 name=ivan balance= state=
;
run;
data:image/s3,"s3://crabby-images/837a4/837a41d94e2cc4e3fc2cf4eb19150b1b18b9667c" alt="outline-of-original-data"
Simplest possible proc freq
Outputs the frequency for each value in column <column>
on table <library>.<source_table>
.
proc freq data=mytable;
tables state;
run;
data:image/s3,"s3://crabby-images/837a4/837a41d94e2cc4e3fc2cf4eb19150b1b18b9667c" alt="outline-of-original-data"
data:image/s3,"s3://crabby-images/d934c/d934ccb31faa6ac6bb261aa842eb7a43dc66749e" alt="proc-freq"
state
column
Save output to another table
Do proc freq while also saving the results to othertable
proc freq data=mytable;
tables <column> / out=othertable;
run;
Show missing data separately
Output a frequency table and a histogram for column <column>
on table <library>.<source_table>
, including missing data as a separate category.
proc freq data=mytable;
tables state / missing;
run;
data:image/s3,"s3://crabby-images/837a4/837a41d94e2cc4e3fc2cf4eb19150b1b18b9667c" alt="outline-of-original-data"
data:image/s3,"s3://crabby-images/c8ae9/c8ae9a817067ea9a46d15c95ae673ee8964f78fa" alt="proc-freq-with-missing-data"
Proc freq with histogram
Output a frequency table and a histogram for column state
.
ods graphics on;
proc freq data=mytable;
tables state / plots=freqplot();
run;
data:image/s3,"s3://crabby-images/837a4/837a41d94e2cc4e3fc2cf4eb19150b1b18b9667c" alt="outline-of-original-data"
data:image/s3,"s3://crabby-images/d965c/d965c2dc786ea9d23fe01ee988eb0129c5790af0" alt="alt text"
Histogram with continuous data
It's very common to create a FORMAT to bin your data into separate groups, so that you can view continuous data as buckets.
proc format;
value balance_bins
0 = "Exactly 0"
0 -< 10 = "Up to US$ 10"
10 -< 20 = "From US$ 10 to US$ 20"
20 -< 30 = "From US$ 20 to US$ 30"
30 -< 40 = "From US$ 30 to US$ 40"
40 -< 50 = "From US$ 40 to US$ 50"
50 - high = "Above US$ 50"
. = "No data"
other = "???";
run;
ods graphics on;
proc freq data=mytable;
tables balance/ missing plots=freqplot;
format balance balance_bins.;
run;
data:image/s3,"s3://crabby-images/837a4/837a41d94e2cc4e3fc2cf4eb19150b1b18b9667c" alt="outline-of-original-data"
data:image/s3,"s3://crabby-images/89233/8923344d733a72a47e772172054dff2d9105f6e2" alt="proc-freq-with-format"
Two-way histogram
You want to see the distribution of one categorical variable versus the other.
This will group the results by the FIRST element, namely
state
. You can also usegroupby=column
to group the results byname
ods graphics on;
proc freq data=mytable;
tables state*name / plots=freqplot(groupby=row twoway=stacked);
run;
data:image/s3,"s3://crabby-images/837a4/837a41d94e2cc4e3fc2cf4eb19150b1b18b9667c" alt="outline-of-original-data"
data:image/s3,"s3://crabby-images/cd036/cd03625a1aff79c9d847d455e65093cf4fd3264c" alt="two-way-proc-freq-histogram"
Two-way histogram with continuous data
Again, use proc format
to turn continuous into discrete data:
proc format;
value balance_bins
0 = "Exactly 0"
0 -< 10 = "Up to US$ 10"
10 -< 20 = "From US$ 10 to US$ 20"
20 -< 30 = "From US$ 20 to US$ 30"
30 -< 40 = "From US$ 30 to US$ 40"
40 -< 50 = "From US$ 40 to US$ 50"
50 - high = "Above US$ 50"
. = "No data"
other = "???";
run;
ods graphics on;
proc freq data=mytable;
tables state*balance / plots=freqplot(groupby=row twoway=stacked);
format balance balance_bins.;
run;
data:image/s3,"s3://crabby-images/837a4/837a41d94e2cc4e3fc2cf4eb19150b1b18b9667c" alt="outline-of-original-data"
data:image/s3,"s3://crabby-images/75dbb/75dbbc6bbb34b61c9f8dcbbe7c88010ed15f7c1a" alt="two-way-proc-freq"