BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
SAS_inquisitive
Lapis Lazuli | Level 10

Hello,

 

I want to populate var2 with subsequent record value if the var1 is missing.

 

data test;
input var1 $ ;
cards;
.
abc
;
run;

data want;
  set test;
  var2=substr(var1,1,1);
run;

Desired output:

var1         var2

.                a

abc           a

1 ACCEPTED SOLUTION

Accepted Solutions
Kurt_Bremser
Super User

Merge the dataset with itself, but start one observation later:

data want;
merge
  test
  test (firstobs=2 rename=(var1=var1x))
;
if var1 = ' '
then var2 = substr(var1x,1,1);
else var2 = substr(var1,1,1);
drop var1x;
run;

View solution in original post

1 REPLY 1
Kurt_Bremser
Super User

Merge the dataset with itself, but start one observation later:

data want;
merge
  test
  test (firstobs=2 rename=(var1=var1x))
;
if var1 = ' '
then var2 = substr(var1x,1,1);
else var2 = substr(var1,1,1);
drop var1x;
run;
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
  • 1 reply
  • 979 views
  • 1 like
  • 2 in conversation