楼主: 红通通
1767 5

[问答] 求教 if _n_=2 then set b; [推广有奖]

  • 2关注
  • 0粉丝

硕士生

43%

还不是VIP/贵宾

-

威望
0
论坛币
1367 个
通用积分
2.9500
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
3610 点
帖子
37
精华
0
在线时间
284 小时
注册时间
2013-3-11
最后登录
2024-3-5

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
请高手指点下:
data b;
input gg;
datalines;
1
;
run;

data all;
if _n_=2 then set b;
run;
proc print;run;


结果为:
gg
.

求教if _n_=2 then set b; 的运行原因,多谢!
二维码

扫码加我 拉你入群

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

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

关键词:Then Set The Input Lines

沙发
baiyaoqian 发表于 2016-10-20 12:22:41 |只看作者 |坛友微信交流群
我的理解是:首先_n_的初始值为1, 编译阶段 pdv里存放变量gg,
由于_n_=2导致 set b语句未执行,不实际读入b数据集的值,data步终止,输出的gg值为缺失值
我试了下面的语句,会输出两条记录。
data b;
input gg;
datalines;
1
2
3
;
run;

data all;
n=_n_;
if n=1 then set b;
run;
proc print;run;

使用道具

藤椅
红通通 发表于 2016-10-20 15:09:36 |只看作者 |坛友微信交流群
我觉得您说的有道理,应该就是没执行的原因。
您举得这个例子为啥会出2条记录呢?多谢

使用道具

板凳
红通通 发表于 2016-10-20 15:11:05 |只看作者 |坛友微信交流群
baiyaoqian 发表于 2016-10-20 12:22
我的理解是:首先_n_的初始值为1, 编译阶段 pdv里存放变量gg,
由于_n_=2导致 set b语句未执行,不实际读入 ...
我觉得您说的有道理,应该就是没执行的原因。
您举得这个例子为啥会出2条记录呢?多谢

使用道具

报纸
红通通 发表于 2016-10-20 15:17:24 |只看作者 |坛友微信交流群
baiyaoqian 发表于 2016-10-20 12:22
我的理解是:首先_n_的初始值为1, 编译阶段 pdv里存放变量gg,
由于_n_=2导致 set b语句未执行,不实际读入 ...
难道是_n_第2次自动变成2,则n=2, set b 继续为1,但遇到if _n_=1 而出发停止?

使用道具

地板
baiyaoqian 发表于 2016-10-21 14:28:38 |只看作者 |坛友微信交流群
红通通 发表于 2016-10-20 15:11
我觉得您说的有道理,应该就是没执行的原因。
您举得这个例子为啥会出2条记录呢?多谢
第一次循环时_n_=1,满足条件,读取一条记录,
然后_n_变为2,此时pdv中 gg的值仍为上次读入的,
第二次循环将 n=2 gg=1, 写入,所以是两条结果。

因if条件不满足,不再读入新记录,_n_值不变,所以最终是两条记录,
n gg
1  1
2  1

使用道具

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

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

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

GMT+8, 2024-5-2 23:34