BookmarkSubscribeRSS Feed
mmaximos
Obsidian | Level 7

Hello all, 

 

I'm looking to split a datasets based on one of the variables. Currently in the drug column I have two medications: drug a and drug b, I want to have one dataset include just drug a and the other just drug b.

The code I tried is as follows but no success. Best way to correct this?

 

Thank you

Data mydata;
	Set sample;
	Where location= "country" and code= "anti-infective";
	Keep drug vol time_period;
Run;

data mydata.a;
set mydata;
keep drug= a;
run;

data mydata.b;
set mydata;
keep drug= b;
run;

 

 

6 REPLIES 6
PaigeMiller
Diamond | Level 26

Generally, splitting up a data set is not necessary and not productive. So let's abandon that idea.

 

If you want to perform an analysis using a certain PROC on part of the data set, you can do this:

 

proc something data=mydata(where=(drug='a'));

 

or better yet, you can use BY statements to have analyses performed on both drug A and drug B with one piece of code.

 

proc something data=mydata;
     by drug;
     /* Other statements for the PROC go here */
run;

 

which assumes that MYDATA is sorted by DRUG

--
Paige Miller
mmaximos
Obsidian | Level 7

Amazing, thank you! I'll give this a try. 

Reeza
Super User

To answer your question directly as asked, KEEP selects variables in a data set not observations.
WHERE filters observations in a data sets. Changing KEEP to WHERE in your code will get you the desired results. 

 

data mydata.a;
set mydata;
where drug= "a"; *note that this is case sensitive as well;
run;

data mydata.b;
set mydata;
where drug= "b";
run;

However, @PaigeMiller is correct, you usually do not want to do this, his solution is preferable. 

mmaximos
Obsidian | Level 7

Thank you

Kurt_Bremser
Super User

The KEEP statement and the KEEP= dataset option control which variables go into the output, not which observations. Use a WHERE statement, like you did in your first step.

mmaximos
Obsidian | Level 7

Thank you!

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
  • 3113 views
  • 3 likes
  • 4 in conversation