全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
2685 6
2015-11-17
SAS base 70中的一道题,
data test;
if age not in (15,16) then g=1;
else g=2;
input age @@;
cards;
14 15 16 17
;
run;

为什么g 都等于1 ?去掉not 所有g 都等于2?
二维码

扫码加我 拉你入群

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

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

全部回复
2015-11-17 21:45:36
你顺序都搞错了,应该是:
data test;
input age @@;
if age not in (15,16) then g=1;
else g=2;
cards;
14 15 16 17
;
run;
二维码

扫码加我 拉你入群

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

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

2015-11-17 22:42:56
因为age还未赋值的时候为空值 每读一行结束后 由于没有retain age又会被置为空值
你可以在if前面加一个put age看下age当前的值
也可以加一个retain age看下区别
二维码

扫码加我 拉你入群

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

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

2015-11-18 14:41:16
木叶知秋 发表于 2015-11-17 22:42
因为age还未赋值的时候为空值 每读一行结束后 由于没有retain age又会被置为空值
你可以在if前面加一个pu ...
非常感谢
二维码

扫码加我 拉你入群

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

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

2015-11-19 09:55:27
题目错了吧? 为何我在70里找不到这个题
二维码

扫码加我 拉你入群

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

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

2015-11-20 15:14:20
feng_2long 发表于 2015-11-19 09:55
题目错了吧? 为何我在70里找不到这个题
61.Consider the data step:
data WORK.TEST;
   infile 'c:\class1.csv' dsd;
   input Name $ Sex $ Age Height Weight;
   if Age NE 16 and Age NE 15 then Group=1;
   else Group=2;
run;
Which statement produces a functionally equivalent result for assigning Group a value?
     A. if Age not in(15,16) then Group=1;  else Group=2;
     B. if (Age NE 16) or (Age NE 15) then Group=1;  else Group=2;
     C. where Age not between 15 and 16 then Group=1; else Group=2;
     D. both A or C will work.
二维码

扫码加我 拉你入群

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

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

点击查看更多内容…
相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群