行保持说明符@和@@用法详解

来源:互联网 发布:手机淘宝旧版5.2.2 编辑:程序博客网 时间:2024/06/16 02:39
行保持说明符@和@@用法详解:

多个input语句读取同一数据行的数据,使用单尾随符@
一个input语句在一个输入行中读取多个观测,则使用双尾随符@@

例1:
data b;
*input x y @;
input x y @@;
datalines;
3.16 2.9 5.8 3 4.9 4.17
;
proc print;
run;

例2:
data aa;
*input xxx @; 
input xxx @@; 
cards;
1 2 3
4 5 6
;
run;
proc print;
run;

例3: 经典的例子
data test;
*infile cards; 
input x @;   /*单个@,能Hold住,有效期到下一个input语句*/
input y;     /*没有@,Hold不住,下一个input语句会去读新的一行*/
input z @@;  /*两个@,Hold住没问题,保持当前行直到该行结束*/
cards;
1 2 3 4 5 6
7 8 9 10 11 12
13 14 15 16 17
;
run;
proc print data=test;
run;

输出结果:
Obs x y z 
1 1 2 7 
2 8 9 13 

解读:
@是保持当前行,直到遇到下一个后面不带有@的input语句或是进入下一个数据步循环,@@是保持当前行直到该行结束(可以跨域数据步循环)。

第一次循环:
input x @;   读入x的值(1),并保持在当前行(第一行)
input y;     读入y的值(2),并把输入指针指向下一行(第二行开头)
input z @@;  读入z的值(7),并保持该行到下一数据步循环

第二次循环
input x @;   读入x的值(8),并保持在当前行(第二行中间)
input y;     读入y的值(9),并把输入指针指向下一行(第三行开头)

input z @@;  读入z的值(13),并保持该行到下一数据步循环

以此类推......
利用put _all_,查看详细执行过程
data test;
put _all_; 
input x @;
put _all_;
input y;
put _all_;
input z @@;
put _all_;
cards;
1 2 3 4 5 6
7 8 9 10 11 12
13 14 15 16 17
;
run;
proc print data=test;
run;
原创粉丝点击