BookmarkSubscribeRSS Feed
☑ This topic is solved. Need further help from the community? Please sign in and ask a new question.
Ronein
Meteorite | Level 14

Hello

I have  a data set with 4 columns.

I need to copy the values of fields : X3 ,X4 down.

It means that for x1=1111 :

the values 1000,400 will copy down to 11 rows and values  3000,8000 will copy down to 11 rows.

In real life I  have a data set with millions of rows and this action should be done for each group(that is defined by x1,x2)

 

Data have;
input X1 X2 X3 X4;
cards;
1111 2205 1000 4000
1111 2204 . .
1111 2203 . .
1111 2202 . .
1111 2201 . .
1111 2112 . .
1111 2111 . .
1111 2110 . .
1111 2109 . .
1111 2108 . .
1111 2107 . .
1111 2106 . .
1111 2205 3000 8000
1111 2204 . .
1111 2203 . .
1111 2202 . .
1111 2201 . .
1111 2112 . .
1111 2111 . .
1111 2110 . .
1111 2109 . .
1111 2108 . .
1111 2107 . .
1111 2106 . .

2222 2205 7000 2700 2222 2204 . . 2222 2203 . . 2222 2202 . . 2222 2201 . . 2222 2112 . . 2222 2111 . . 2222 2110 . . 2222 2109 . . 2222 2108 . . 2222 2107 . . 2222 2106 . . 2222 2205 1500 5500 2222 2204 . . 2222 2203 . . 2222 2202 . . 2222 2201 . . 2222 2112 . . 2222 2111 . . 2222 2110 . . 2222 2109 . . 2222 2108 . . 2222 2107 . . 2222 2106 . . ; run;
1 ACCEPTED SOLUTION

Accepted Solutions
PaigeMiller
Diamond | Level 26

Seems like a RETAIN statement is what you need.

 

data want;
    set have (rename=(x3=x3a x4=x4a));
    retain x3 x4;
    if not missing(x3a) then x3=x3a;
    if not missing(x4a) then x4=x4a;
    drop x3a x4a;
run;
--
Paige Miller

View solution in original post

5 REPLIES 5
PaigeMiller
Diamond | Level 26

Seems like a RETAIN statement is what you need.

 

data want;
    set have (rename=(x3=x3a x4=x4a));
    retain x3 x4;
    if not missing(x3a) then x3=x3a;
    if not missing(x4a) then x4=x4a;
    drop x3a x4a;
run;
--
Paige Miller
AlexBennasar
Obsidian | Level 7
data want;
	retain _x3 _x4;
	set have;

	if not missing(x3) and not missing(x4) then
		do;
			_x3=x3;
			_x4=x4;
		end;
	else
		do;
			x3=_x3;
			x4=_x4;
		end;
	drop _x3 _x4;
run;
andreas_lds
Jade | Level 19

The line

1111 2106 . .2222 2205 7000 2700

seems to be not right.

Similar problems have been asked and answered many times. What have you tried?

If groups are defined by x1 and x2, which values do you expect for the second obs?

Ksharp
Super User

data want;
update have(obs=0) have;
by x1;
output;
run;
Kurt_Bremser
Super User

@Ronein wrote:

should be done for each group(that is defined by x1,x2)

Then there will never be a copy forward, as all x2 values are unique within a x1 group, so all these groups consist of exactly one observation.

Please review your post.

SAS Innovate 2025: Save the Date

 SAS Innovate 2025 is scheduled for May 6-9 in Orlando, FL. Sign up to be first to learn about the agenda and registration!

Save the date!

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
  • 5 replies
  • 1267 views
  • 3 likes
  • 6 in conversation