全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
6245 4
2013-03-04
The contents of the raw data file EMPLOYEE are listed below:
----|----10---|----20---|----30
Ruth 39 11
Jose 32 22
Sue 30 33
John 40 44
The following SAS program is submitted:
data test;
in file' employee';
input employee_ name $ 1-4;
if employee_ name = 'Sue' then input age 7-8;
else input idnum 10-11;
run;
Which one of the following values does the variable AGE contain when the name of
the employee is "Sue"?
A. 30
B. 33
C. 40
D. . (missing numeric value)
Answer: C

二维码

扫码加我 拉你入群

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

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

全部回复
2013-3-4 14:32:43
data test;
infile datalines;
input employee_name $ 1-4;
if employee_name = 'Sue' then input age 7-8;
else input idnum 10-11;
datalines;
Ruth  39 11
Jose  32 22
Sue   30 33
John  40 44
;
run;
上面这段code跟你这道题目本质是一样的,这里是用到的是column input,读到第一行时,employee_name=“Ruth”而不是“Sue”,故执行 input idnum 10-11语句,由于又遇到了input,指针实际已经跳到下一行了,也就是Jose这一行,将column10-11的22赋值给idnum,而age却没有赋值,就为空值

后面的类似循环,所以test中实际上只有两条记录,当employee_name=“Sue”时age为40,而idnum为空值
二维码

扫码加我 拉你入群

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

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

2013-3-4 21:54:21
在input employee_name $ 1-4;后面没有@, 因此在读入第一行的1-4列后,employee_name=“Ruth”, 而数据指针已经移动到第二行了. 此时employee_name 不等于 'Sue', 因此对第二行执行 input idnum 10-11, 使idnum=22, 第一个观测结束读取.
第二个观测从第三行开始读取, 读取后 employee_name='Sue', 同样因为没有@,  数据指针移动到第四行. 此时因为employee_name 等于 'Sue', 因此对第四行数据执行 input age 7-8, 使age=40.
此题主要考数据指针的移动, 有无结尾@的区别.
二维码

扫码加我 拉你入群

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

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

2013-3-4 23:43:35
PhoenixHuang 发表于 2013-3-4 21:54
在input employee_name $ 1-4;后面没有@, 因此在读入第一行的1-4列后,employee_name=“Ruth”, 而数据指针已 ...
那是说明因为这里面用了if, 所以有没有@会影响结果吗?
二维码

扫码加我 拉你入群

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

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

2013-3-5 09:32:02
wangzhuo422 发表于 2013-3-4 23:43
那是说明因为这里面用了if, 所以有没有@会影响结果吗?
加一个@, 结果完全不一样. 加了@后,  这题的答案就是30
二维码

扫码加我 拉你入群

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

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

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

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