楼主: skidrowxu
1825 3

[问答] 关于多个set statement的疑问 [推广有奖]

  • 0关注
  • 0粉丝

高中生

55%

还不是VIP/贵宾

-

威望
0
论坛币
-1 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
88 点
帖子
10
精华
0
在线时间
45 小时
注册时间
2016-7-10
最后登录
2017-4-28

相似文件 换一批

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
我有这么两个dataset

DATAone;

INPUTx y z $;

CARDS;

1 2 a1

1 3 b1

1 . c1

2 5 d1

4 6 e1

;

run;


DATAtwo ;

N+1;

INPUTy z2 $;

CARDS;

2 a1

3 b1

4 c1

5 d1

6 e1

;

run;


需要运行下面的程序

DATAboth;

SETone ;

N = .;

IFy=. THEN DOWHILE (z NE z2);

SETtwo;

END;

run;


最终的结果为

运行结果


但我逻辑上实在是看不懂,为什么是条件是(z NE z2),而不是(z eq z2)

希望高人解答

二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:statement Statemen Statem State ATE 程序

111.png (5.7 KB)

运行结果

运行结果

沙发
manchengfu 发表于 2016-12-4 17:10:57 |只看作者 |坛友微信交流群
其实把最后一段代码加几个put就比较清楚了。
两个set的时候,SAS是按顺序读完第一个set里one的一条数据之后,再读第二个set里two中的一条数据。这里由于有了if 和do 循环,在y=.的时候two的数据是读了多次的。因为do while 的条件,只要z ne z2该条数据就一直被循环覆盖。恰恰当z eq z2时,覆盖停止了,也就是取了最后的结果值。


  1. DATA both;
  2. SET one ;
  3. put _all_;
  4. N = .;
  5. IF y=. THEN DO WHILE (z NE z2);
  6. put z z2;
  7. put _all_;
  8. SET two;
  9. put z z2;
  10. put _all_;
  11. END;
  12. run;
复制代码

x=1 y=2 z=a1 N=. z2=  _ERROR_=0 _N_=1
x=1 y=3 z=b1 N=. z2=  _ERROR_=0 _N_=2
x=1 y=. z=c1 N=. z2=  _ERROR_=0 _N_=3
c1
x=1 y=. z=c1 N=. z2=  _ERROR_=0 _N_=3
c1 a1
x=1 y=2 z=c1 N=1 z2=a1 _ERROR_=0 _N_=3
c1 a1
x=1 y=2 z=c1 N=1 z2=a1 _ERROR_=0 _N_=3
c1 b1
x=1 y=3 z=c1 N=2 z2=b1 _ERROR_=0 _N_=3
c1 b1
x=1 y=3 z=c1 N=2 z2=b1 _ERROR_=0 _N_=3
c1 c1
x=1 y=4 z=c1 N=3 z2=c1 _ERROR_=0 _N_=3
x=2 y=5 z=d1 N=3 z2=c1 _ERROR_=0 _N_=4
x=4 y=6 z=e1 N=. z2=c1 _ERROR_=0 _N_=5
NOTE: 从数据集 WORK.ONE. 读取了 5 个观测
NOTE: 从数据集 WORK.TWO. 读取了 3 个观测
NOTE: 数据集 WORK.BOTH 有 5 个观测和 5 个变量。
NOTE: “DATA 语句”所用时间(总处理时间):
      实际时间          0.06 秒
      CPU 时间          0.04 秒




已有 1 人评分学术水平 热心指数 信用等级 收起 理由
skidrowxu + 1 + 1 + 1 精彩帖子

总评分: 学术水平 + 1  热心指数 + 1  信用等级 + 1   查看全部评分

使用道具

藤椅
manchengfu 发表于 2016-12-4 22:27:11 |只看作者 |坛友微信交流群
如果do while 的条件变成 z eq z2,那么因为set two是在后面,这时z2是空的,直接停止了读取two。

使用道具

板凳
skidrowxu 发表于 2016-12-5 17:35:43 |只看作者 |坛友微信交流群
manchengfu 发表于 2016-12-4 17:10
其实把最后一段代码加几个put就比较清楚了。
两个set的时候,SAS是按顺序读完第一个set里one的一条数据之后 ...
谢谢你,加上put statement后,一目了然

使用道具

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

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-5-1 09:41