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

Hi Experts,

 

I am trying to get the below output. I have tried a few things but was not able to get what i wanted.

 

I have two datasets, have1 and have2, i want to search for a string in have1 and insert values from dataset 2 when there is a specific value.

 

 

data have1;
length name $5;
input name ;
datalines;
ABC
EFD
-----
FGH
;
run;

data have2;
length filler $5;
input filler;
datalines;
FFF
GGG
HHH
;
run;

the final dataset want will be used to write out to a text file.

 

Is it possible? 

thanks in advance.

 

Manjeet


Cheers from India!

Manjeet
1 ACCEPTED SOLUTION

Accepted Solutions
Kurt_Bremser
Super User

OK, so the ----- is one observation and not a certain sequence of observations.

Based on what I remember from your original intended result, this should work:

data want;
set have1;
if name = '-----'
then do until (done);
  set have2 end=done;
  name=filler;
  output;
end;
else output;
drop filler;
run;

This will fail if you have more than one "-----" observation.

View solution in original post

6 REPLIES 6
mnjtrana
Pyrite | Level 9

done.


Cheers from India!

Manjeet
Kurt_Bremser
Super User

OK, so the ----- is one observation and not a certain sequence of observations.

Based on what I remember from your original intended result, this should work:

data want;
set have1;
if name = '-----'
then do until (done);
  set have2 end=done;
  name=filler;
  output;
end;
else output;
drop filler;
run;

This will fail if you have more than one "-----" observation.

Astounding
PROC Star

A variation for multiple "-----" values:

 

data want;

set have1;

if name = '-----' then do i=1 to _nobs_;

   set have2 point=i nobs=_nobs_;

   name=filler;

   output;

end;

else output;

drop filler;

run;

mnjtrana
Pyrite | Level 9

@Kurt_Bremser

 

thanks Kurt. this is exactly what i was looking for.

 

Cheers from India!

 

Manjeet


Cheers from India!

Manjeet
DanielSantos
Barite | Level 11

Hi.

 

If you won't mind transforming have2 by including a key and index, you could try this which will work for every '-----' found in have1:

 

* create key and index over have2;
data have3 (index=(NAME));
set have2;
NAME='-----';
run;

data want;
set have1;
drop FILLER;

do until (_ERROR_); * cycle through have2;
   set have3 key=NAME; 
   if not _ERROR_ then do; * match;	  
      NAME=FILLER;
      output;
	  NAME='-----';	  
   end;
   else if NAME ne '-----' then output; * no match;
end;
_ERROR_=0;
run;

What you are trying to do is actually a left join. 

 

The code above is an old technique which uses an index to reset the cursor over have2 when the key will not match.

 

Other similar approaches could be:

 

Load have2 into an hash table and iterate through it.

SQL left join of have1 with have2.

 

Hope it helps.

 

Daniel Santos @ www.cgd.pt

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
  • 2155 views
  • 5 likes
  • 4 in conversation