SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 734|回复: 4
打印 上一主题 下一主题

请教一个data step的问题

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2010-8-9 03:52:29 | 只看该作者

请教一个data step的问题

现在有一个data,
data x;
input x $ y $ z;
cards;
a 1 2
a 2 2
a 3 3
a 4 1
a 6 2
b 2 4
b 3 3
b 4 5
b 6 1
c 3 0
c 6 1
;
其中y相当于星期几,像A的只有一二三四六,缺少星期五以及星期天,现在假定缺少的都看作是0.
怎样才能构建一个新的数据,把它变成以下的形式呢
data y;
input x $ y $ z;
cards;
a 1 2
a 2 2
a 3 3
a 4 1
a 5 0
a 6 2
a 7 0
b 1 0
b 2 4
b 3 3
b 4 5
b 5 0
b 6 1
b 7 0
c 1 0
c 2 0
c 3 0
c 4 0
c 5 0
c 6 1
c 7 0
;
run;
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2010-8-9 07:03:59 | 只看该作者

Re: 请教一个data step的问题

[code:2gg9s09g]proc sort nodupkey; by x y; run;
data _temp;
        set x(keep = x); by x;
        length y $8.;
        if first. x then do _n_ = 1 to 7;
                y = put(_n_, F1.); z = 0;
                output;
        end;
run;

data have;
        update _temp x; by x y;
run;[/code:2gg9s09g]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2010-8-9 11:17:03 | 只看该作者

Re: 请教一个data step的问题

[code:3repb8qw]data raw;
        input x $ y z;
cards;
a 1 2
a 2 2
a 3 3
a 4 1
a 6 2
b 2 4
b 3 3
b 4 5
b 6 1
c 3 0
c 6 1
;
data out(drop=y rename=(start=y));
        set raw;
        by x;
        if first.x then start=1;
        do while(start lt y);
                z=0;
                output;
                start+1;
        end;
        set raw point=_n_;
        output;
        start+1;
        if last.x then
                do while(start le 7);
                        z=0;
                        output;
                        start+1;
                end;
run;[/code:3repb8qw]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
地板
 楼主| 发表于 2010-8-9 12:40:17 | 只看该作者

Re: 请教一个data step的问题

好啊。每次我仔细阅读楼上哥们的程序,我都受益匪浅。
[code:3danto1y]
data out1;
        set raw; by x notsorted;
        array zz{7} _temporary_;
        if first.x then do _n_ = 1 to 7;       
                zz[_n_] = 0;
                end;
        zz[y] = z;
        if last. x then do y =1 to 7;
                z = zz[y];
                output;
                end;
run;[/code:3danto1y]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
5#
 楼主| 发表于 2010-8-9 14:01:05 | 只看该作者

Re: 请教一个data step的问题

的确是这样,每次都能从回复中受益匪浅阿
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|手机版|Archiver|SAS中文论坛  

GMT+8, 2026-2-4 01:40 , Processed in 0.070242 second(s), 20 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表