Using SAS is amazing. I did my first analytics project using SAS, and would like to share with newbies if it can help others. In my analytics project utilizing SAS, I employed a systematic approach to explore and analyze structured data. Beginning with the table creation with INPUT statement, I easily created my dataset. Leveraging PROC PRINT, I gained a comprehensive overview of the dataset’s structure, identifying key variables and initial patterns.
To enhance data organization, PROC SORT played a pivotal role, arranging the dataset based on specified variables. This step not only facilitated a clearer understanding of the data but also set the stage for subsequent analyses. By applying PROC MEAN, I look into statistical summaries, extracting crucial insights into variations within the dataset.
Further enriching my analysis, PROC FREQ provided a detailed examination of categorical variables, shedding light on distribution patterns and enabling me to identify noteworthy trends. In concert, these SAS procedures empowered a strong exploration of my analytics project, ensuring good data understanding.
Creating a Data Set Table
/* Create A table named class with variables “name age Gender grade marks subject” */
data class;
input name$ age Gender$ grade marks subject$ TotalMarks Status$;
cards;
anum 13 female 7 49 maths 50 Pass
ali 14 male 8 44 maths 50 Pass
saim 12 male 6 48 maths 50 Pass
sofia 15 female 9 46 physics 50 Pass
lari 15 male 8 15 physics 50 fail
ali 13 male 7 45 maths 50 Pass
ali 13 male 7 45 maths 50 Pass
tahir 14 male 8 45 maths 50 Pass
sara 15 female 9 48 physics 50 Pass
jawad 15 male 9 46 physics 50 Pass
;
run;
data:image/s3,"s3://crabby-images/0eb5a/0eb5a6e263f135c3e3931ff3fcd60ac9b197b80e" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/dfd3b/dfd3b2af275e9c4ec3bcd30d1d1fbab84a74878f" alt="SAS Coding Project"
Proc Contents
/* display the content in the table */
proc contents data=class;
run;
data:image/s3,"s3://crabby-images/5db52/5db527a23a1df671b8087c675640c4180020d267" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/e7ece/e7ece4224fca035b7c898468f74b88c119294e24" alt="SAS Coding Project"
Proc Print
/* Print the data set class */
proc print data=class;
run;
data:image/s3,"s3://crabby-images/770a5/770a532d0dfee726f35ed961560fa78320507659" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/a6fe1/a6fe1f65d3ec1cd45941c10f1a0d30623aeefa93" alt="SAS Coding Project"
/* list first 5 rows */
proc print data=class (obs=5);
run;
data:image/s3,"s3://crabby-images/920f0/920f0fe19fb0dfaa4078fd8fc6350ae07e2d7086" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/c4035/c4035694c449202ebb44f7db3c6a5622aebd8c96" alt="SAS Coding Project"
/* filtering rows with Basic Operators */
proc print data=class;
WHERE Gender=’female’;
run;
data:image/s3,"s3://crabby-images/60283/60283d858e81226c2cac98349788327406ff87fa" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/a8835/a8835d34196eb907cf17715e40638e0d5b63ed03" alt="SAS Coding Project"
proc print data=class;
WHERE marks>45;
run;
data:image/s3,"s3://crabby-images/f50d3/f50d3aa93d9fc8b6d0445fde814846f2c62af70b" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/23803/23803332e5bacb1d1aadb07a4cc2dc548d4e09ce" alt="SAS Coding Project"
proc print data=class;
WHERE name=’ali’ and subject=’maths’;
run;
data:image/s3,"s3://crabby-images/84d58/84d5858a4113b2e45a416e60f4dc8c4a784b616a" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/d610a/d610a253835709334988f80d7dcdd549940ceed5" alt="SAS Coding Project"
proc print data=class;
WHERE marks>40 or marks=40;
var subject=maths;
run;
data:image/s3,"s3://crabby-images/c2622/c26224788d24a659f31f2ee00974950b1101e5f2" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/35a5f/35a5f37f51d6a9df1f07cfb5b4084d7186d3c416" alt="SAS Coding Project"
Proc Sort
*Proc sort statement ;
Proc sort data=Class out=classReport noduprecs dupout=class_dups;
by _all_;
run;
data:image/s3,"s3://crabby-images/28adb/28adbf16258dd71902476b73228281b6abd33ffe" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/6a22d/6a22dbdeb6cf447b30b8d673e7592e89844795ad" alt="SAS Coding Project"
Proc sort data=Class out=classReport;
where gender=’male’;
by descending name;
run;
data:image/s3,"s3://crabby-images/f241e/f241e9eec0706019b1a41d671e8aad27b19f6917" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/30906/30906051fd9c5f0223123bd8cff47dea3c011b14" alt="SAS Coding Project"
Proc Means
/* calculate summary statustucs */;
proc means data=class;
var marks age;
run;
data:image/s3,"s3://crabby-images/56a97/56a973eb8bb524a9cf8d37a248e322a6c48d6319" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/c9677/c9677846f0ff5bf95142bf887f9454ab216965d2" alt="SAS Coding Project"
Proc Freq
/* create frequency table for age variable */
/* list unique values and frequecies */
proc freq data=class;
table age;
run;
data:image/s3,"s3://crabby-images/65494/65494889962a2d9477d5a208cc5d6948db8a3f53" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/fad99/fad99a4772c3737a8e672420c3d11b9c63bb6587" alt="SAS Coding Project"
/* create frequency table for age variable and suppress Cumulative
Percentage */
proc freq data=class;
table age / nocum;
run;
data:image/s3,"s3://crabby-images/f3866/f38665455bb451477632c0175670ec3b52774947" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/144b0/144b0e590cfde178ef451ab5895beca757b339b6" alt="SAS Coding Project"
/* create frequency table for marks variable and suppress percentages */
proc freq data=class;
tables marks / nopercent nocum;
run;
data:image/s3,"s3://crabby-images/dacac/dacacc28c62de687a090141a0caf19ea21dc44e7" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/11c6c/11c6cad7d56643a8b8e4d219bd643a61bb62a9fc" alt="SAS Coding Project"
proc freq data=class;
where grade=9;
tables marks / nopercent nocum;
run;
data:image/s3,"s3://crabby-images/65f94/65f94490b21a484e86261fb498165f0c14ff1604" alt="SAS Coding Project"
data:image/s3,"s3://crabby-images/422ce/422ce94fbec811af6ec8070e1f1521528d7d729d" alt="SAS Coding Project"
ODS Graphics On
ods graphics on;
proc freq data=class;
tables Subject*marks*Gender / chisq cmh plots(only)=freqplot(twoway=cluster);
weight age;
run;
ods graphics off;