BookmarkSubscribeRSS Feed
brophymj
Quartz | Level 8

Is there a simple way of duplicating the key until it reaches the next values so

key

5564

blank

blank

blank

5566

becomes

5564

5564

5564

5566

5566

thanks

I have attached my dataset

1 REPLY 1
RW9
Diamond | Level 26 RW9
Diamond | Level 26

You can use retain:

data have;

  key=5564; output;

  key=.; output;

  key=.; output;

  key=.; output;

  key=5566; output;

run;

data want (drop=key rename=(new_key=key));

  set have;

  retain new_key;

  if key ne . then new_key=key;

run;

Lag would also work if its a new variable.

sas-innovate-2026-white.png



April 27 – 30 | Gaylord Texan | Grapevine, Texas

Registration is open

Walk in ready to learn. Walk out ready to deliver. This is the data and AI conference you can't afford to miss.
Register now and lock in 2025 pricing—just $495!

Register now

What is Bayesian Analysis?

Learn the difference between classical and Bayesian statistical approaches and see a few PROC examples to perform Bayesian analysis in this video.

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
  • 1138 views
  • 0 likes
  • 2 in conversation