BookmarkSubscribeRSS Feed
shoeGirl37
Calcite | Level 5

Hello,

I have a table that I need to find the frequencies of patient appointments based on group of diagnosis.

I have the table set up where it's showing the months and counts of the appointments and also grouped by diagnosis category, I just need to break it down by each department.

 

When I try to do BY dept or include dept in the matrix, it's giving me 153 tables with every dx category.

Not every dept has every category.

I just need to have the freq for each dept but only the diagnosis included in that dept.

 

Here is what I have:

 

proc freq data=cplr.patientICD9Analysis4;
format Appt_Date monyy7.;
table DeptID*Diagnosis_Category*Appt_Date / nocol nocum norow;
where Provider_Type IN ("Physician", "Resident", "Fellow");

run;
 
Any help would be appreciated
10 REPLIES 10
PaigeMiller
Diamond | Level 26
table DeptID*Diagnosis_Category*Appt_Date / list;
--
Paige Miller
shoeGirl37
Calcite | Level 5

that is good, but is there a way to have it more in a table format?

seems long....

 

PaigeMiller
Diamond | Level 26

"table format"? Can you give an example? Do you want it in a SAS data set? 

--
Paige Miller
shoeGirl37
Calcite | Level 5

I think when proc freq outputs it's divided by dept, it shows me a proc freq output for each dept which is good, but it also outputs all the diagnosis categories.

Is there an output where each table output will only limit to the diagnosis categories part of that dept and not all of them?

 

shoeGirl37
Calcite | Level 5

and I would like to output it to excel

 

PaigeMiller
Diamond | Level 26

Maybe this? This creates a SAS data set named _COUNTS_ as output.

 

proc freq data=cplr.patientICD9Analysis4;
format Appt_Date monyy7.;
by deptid;
table Diagnosis_Category*Appt_Date / noprint list out=_counts_;
where Provider_Type IN ("Physician", "Resident", "Fellow");
run;
--
Paige Miller
Watts
SAS Employee

 

You can use the CROSSLIST format together with the NOSPARSE option in the TABLES statement (in PROC FREQ). 

 

tables DeptID*Diagnosis_Category*Appt_Date / crosslist nosparse;

 

ballardw
Super User

If you provide some example data we might get closer.

 

If you don't need cumulative counts or percentages then Proc tabulate might be what you are looking for.

Try this and see if one is closer to what you want: Proc tabulate can have multiple table statements . The comma indicates a dimension. So the first will have a row heading or department id and date with separate columns for diagnosis category.

The second table would be one "page", or table, per department with rows of date and columns of diagnosis, and the third is rows of diagnosis category and date with columns for department. Tabulate has a number of different percentages so without knowing which makes sense I'm not going to confuse that issue.

proc tabulate data= data=cplr.patientICD9Analysis4;
format Appt_Date monyy7.;
class DeptID Diagnosis_Category Appt_Date ;
where Provider_Type IN ("Physician", "Resident", "Fellow");

table DeptID*Appt_Date ,
      Diagnosis_Category * n;
/*or*/
table DeptID,
      Appt_Date ,
      Diagnosis_Category * n;
/*or */
table Diagnosis_Category*Appt_Date ,
      deptID * n;


run;
shoeGirl37
Calcite | Level 5

So this works great! What if I want to add patientID as a grouping?

 

ballardw
Super User

@shoeGirl37 wrote:

So this works great! What if I want to add patientID as a grouping?

 


Depends on where you want it to appear and how a variable is to be used. That is partially why I mentioned which examples have which things appear in a row, column or page heading. Within any of the dimensions the code when read from left to right with nesting (the *) means that for rows (or page) that the variable values will appear in left to right order. If the dimension is a column dimension then the left most variable would be at the top of a group with the nested values below.

 

For simple counts I would suggest playing around with the variables in a smallish data set like SASHELP.Class or SASHELP.CARS and place the group-like variables in different orders with and without * for nesting and/or ( ) around groups of variables to see what happens. Or read the friendly manual. There are enough concepts involved that SAS publishes a book just on Proc Tabulate.

 

Also Proc Report is very flexible with different approaches to layout. There are tradeoffs in both procedures, Tabulate is probably nicer when you need to nest results in both rows and columns but you can't request statistics in both the row and column generally.

Proc Report allows more flexibility in using values from columns to calculate values in other columns to the right in a table.

 

 

 

Proc Tabulate needs to know how a variable will be used: Grouping usually means the variable goes on a Class statement, if the variable is be used in statistics other than N related, such as Mean, Max, Stddev then the variable needs to be on a VAR statement.

SAS Innovate 2025: Call for Content

Are you ready for the spotlight? We're accepting content ideas for SAS Innovate 2025 to be held May 6-9 in Orlando, FL. The call is open until September 16. Read more here about why you should contribute and what is in it for you!

Submit your idea!

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.

Click image to register for webinarClick image to register for webinar

Classroom Training Available!

Select SAS Training centers are offering in-person courses. View upcoming courses for:

View all other training opportunities.

Discussion stats
  • 10 replies
  • 4022 views
  • 1 like
  • 4 in conversation