全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
4973 7
2011-03-22
在输入数据时,missover与@@为何不可同时使用?造成这种原因的机理是什么?
例:
data A;
      infile datalines dsd missover;
      input x y z @@;
      datalines;
1,,3,4,5
;
run;

运行该程序会出错,但如果想读取一行,让数据集产生两条记录,第二条记录z为缺失,怎么处理?(保留@@,即让输入数据只在一行显示)
二维码

扫码加我 拉你入群

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

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

全部回复
2011-3-22 12:16:15
data a;
input x y @@;
cards;
1 2 3 4
;
data a;
set a;
z=.;
run;

missover 数据不够 也不从下面补充,@@是横向读取补充,所以不能同时用的。
二维码

扫码加我 拉你入群

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

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

2011-3-22 12:32:27
谢谢楼上回答,可能没完全理解我的意思,我只是想知道如何在input中实现z的缺失。
二维码

扫码加我 拉你入群

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

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

2011-3-22 13:45:40
复制代码


以上代码删除了missover和在5的后面加逗号,这可以实现你的目的。

至于missover和@@引起的错误我也不懂,missover是当缺失值发生在行记录后面时,使SAS能正确地识别这是一个缺省值,从而阻止向下一行读取数据。所以你要在第二行实现z的缺省值,就要在5的后面加逗号(因为你一开始就用了逗号做分隔符)
二维码

扫码加我 拉你入群

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

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

2011-3-23 12:39:28
谢谢楼上的回答,我后来也是这么做的,不过这样就有点显示说明后面有缺失了。
二维码

扫码加我 拉你入群

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

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

2011-3-23 16:35:12
5# allen802

似乎missover和@@是不能同时使用的。
如果是要求每次读三组的话,可以用类似这个代码:

data a;
    infile 'c:\test.txt' dsd missover;
    do while (1);
        input x y z @;
        if x=. and y=. and z=. then leave;
    output;
    end;
run;

缺点是,如果出现类似
11,12,13,,,,17,18
本来我们期望的是
11 12 13
.  .  .
17 18 .

但因为出现了一排missing,到13以后的就不能显示了。
二维码

扫码加我 拉你入群

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

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

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

说点什么

分享

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