sas 语句中的@ 或者是@@是什么意思?
两个都是行控制符
@ 表示执行下一个操作时,指针移到下一碰耐个记录。
@@表示执行下一个操作,指针保持在当前早吵禅记录。
给个例子:
data a;
input x y @;
cards;
1 2 3 4
2 2 3 5
3 2 1 1
;run;
proc print data=a;run;
data b;
input x y @@;
cards;
1 2 3 4
2 2 3 5
3 2 1 1
;run;
proc print data=b;run;
结果如下陆尘:
The SAS System 10:58 Saturday, December 24, 2011 1
Obs x y
1 1 2
2 2 2
3 3 2
The SAS System 10:58 Saturday, December 24, 2011 2
Obs x y
1 1 2
2 3 4
3 2 2
4 3 5
5 3 2
6 1 1
SAS语言的作用
SAS是一种专用的数据处理、统计计算语言,但是它也包含一般的高级语言编程能力并扩充了许多数学、统计等方面的函数。
SAS语言的编程计算能力主要由SAS数据步提供。DATA语句以关键字DATA 开头,后面给出一个数据集名,例如:
data out1;
则在本数据步要生成的数据集,其名字为out1。我们也可以省略数据集名,这时SAS自动生成一个临时数据集名。也可以使用特殊名字_NULL_ ,表示本数据步不生成数据集。
一赋值语句
在SAS中用赋值语句计算一个值并存放到变量中。
格式为
变量名 = 表达式;
例如:
avg = (math + chinese)/2;
isfem = (sex='女');
y=sin(x)**2;
newv = .;
其中第一个赋值语句用一个公式计算平均分数。第二个生成一个取值为0或1的变量,性别为女时为1,否则为0。第三个使用了正弦函数和乘方运算。第四个给变量赋了缺失值。
二输出语句
SAS数据步的输出一般是数据集,用赋值语句计算的结果会自动写入数据集。SAS也提供了一个PUT语句用于立即打印输出结果。
PUT语句的语法:
PUT 输出项表
输出项表中只能是变量或字符串,项间用空格隔开。如:
data;
x=0.5;
y=sin(x);
put 'Sine function value of ' x 'is ' y;
run;
结果将在运行记录窗口显示一行
Sine function value of 0.5 is 0.4794255386
PUT说明
⒈在PUT语句中,若在变量名后加“=”,则指定输出项可以显示带有变量名的输出结果。
比如把上程序中的弊蠢竖PUT语句改为
put x= y=;
则结果在LOG窗口显示为档高
X=0.5 Y=0.4794255386
⒉指定变量输出项的具体列位置及小数位数
绝对位置格式:
变量 起始列-结束列.小数位数
比如,
put x 10-20 .6 y 30-40 .6;
指定把X数值显示在第10-20列,保留6位小数,把
Y数值显示在第30-40列,保留6位小数。
在指定的列位置内,数值型数据靠右对齐,字符型
数据靠左对齐。变量为整数值或者字符型则不指定
小数位数。
相对位置格式:
变量 宽度.小数位数(用于数值型)
变量 $宽度.(用于字符型)
如:put x 20.8 y 20.8; 使X占用第1-20列,8位小数,右对齐;Y占用第21-40列,8位小数,右对齐。
而put name $10.;使name占用10列。
输出占位不满指定宽度时,数值型数据向右租大对齐,字符型数据向左对齐。
⒊如果希望PUT语句的输出不产生换行,使下一个PUT的结果可以显示在同一行,只要在PUT 语句结尾处加一个@符。
PUT语句的输出结果缺省情况下被送到运行记录窗口。若在PUT语句之前用FILE语句可以改变PUT语句的输出目的地。如,在PUT语句之前用file print;可以把PUT语句的输出转向到输出窗口。在FILE语句中指定一个包含文件名的字符串可以把PUT语句的输出转向到此文件中。比如file 'tmp.out';输出文件把后续的PUT语句输出转向到当前工作目录下的文件“tmp.out”中,生成tmp.out 。注意当前工作目录在SAS状态栏的右方显示,双击可以更改。文件名也可以指定全路径,比如“C:\SAS\TMP.OUT”。
三分支结构
⒈if...then...else 结构
⒉SELECT结构
1. if...then...else 结构
格式为:
IF 条件 THEN 语句;
ELSE 语句;
例: data temp1
input x @@;
if x0 then put x '是正数';
else put x '是负数';
cards;
1 2 -3 4 -5
;
run;
有时我们在条件成立时需要进行的操作无法用一个语句完成,这时可以使用SAS提供的复合语句功能。例:
data;
input x@@; /*不分行符@@的使用:每读入一天记录后,数据指针保持原位不换行,
继续读下一条记录*/
if x0 then do;
y=2*x;
put 'f(' x ')=' y;
end;
else put 'Data Error!';
cards;
1 2 -3 4 -5
;
run;
如果当条件不成立时,不进行什么操作,可以不使用ELSE及其后面的语句。
2.SELECT结构
格式一:
SELECT (选择表达式);
WHEN(值列表) 语句;
WHEN(值列表) 语句;
……
OTHERWISE 语句;
END;
功能及流程:
执行SELECT结构时,先计算出选择表达式和值列表中的所有值,然后把选择表达式值由前向后与值列表中的值相比,发现相等值则执行对应的语句,然后退出SELECT结构(不再查看后面的值列表)。如果选择表达式的值不等于任何值列表中的值则执行OTHERWISE对应的语句,这种情况下没有OTHERWISE语句会出错。
例:
DATA ;
INPUT month $ @@;
put month @;
SELECT(month);
WHEN('Feb', 'Mar', 'Apr') put '春天';
WHEN('May', 'Jun', 'Jul') put '夏天';
OTHERWISE put '秋天或冬天';
END;
CARDS;
Mar Jun oct
;
run;
格式二:
SELECT;
WHEN(条件) 语句;
WHEN(条件) 语句;
……
OTHERWISE 语句;
END;
这种SELECT语句没有选择表达式,而是在每
一个WHEN语句指定一个条件(逻辑表达式),
执行第一个满足条件的WHEN后的语句。如果所
有条件都不满足则执行OTHERWISE后的语句。
例:
data;
input age @@;
put age @;
SELECT;
WHEN(age=12) put '少年';
WHEN(age35) put '青年';
OTHERWISE put '中老年';
END;
cards;
10 30 50
;
run;
四循环结构
⒈计数DO循环
⒉当型循环
⒊直到型循环
⒈计数DO循环
计数DO循环的格式:
DO 计数变量 = 起始值 TO 结束值 BY 步长;
循环体语句……
END;
这种结构与BASIC中计数循环很类似,功能也相当,只是在SAS中是以关键字DO开头(不是FOR),另外步长用BY引导(不是STEP),而结构以END结束(而不是NEXT)。
其功能与流程:
程序先把计数变量赋值为起始值,如果此值小于等于结束值则执行循环体语句,然后把计数变量加上步长,再判断它是否小于等于结束值,如果是则继续执行循环体,直到计数变量的值大于结束值为止。上述结构中“BY 步长”可以省略,这时步长为1。如果步长取负值,则继续循环的条件是计数变量大于等于结束值。
计数DO循环举例
data;
sum=0;
DO i = 1 TO 10 ;
sum +i;
/*此处sum+i等价于sum=sum+i*/
END;
PUT sum=;
run;
在循环体中可以用LEAVE语句跳出循环(功能与C语言的break语句相当),如:
data;
n=13;
flag=1;
DO i = 2 TO n/2 ;
if mod(n,i)=0 then do;
flag=0;
leave;
end;
END;
if flag=1 then
put n 是素数;
else
put n 不是素数;
run;
⒉当型循环
当型循环的格式:
DO WHILE(循环继续条件);
循环体语句……
END;
程序先判断循环继续条件是否成立,成立时执行循环体语句,再判断循环继续条件,如此重复,直到循环继续条件不再成立。
data;
x=243;
y=63;
z=mod(x,y);
DO WHILE (z ^= 0);
x=y;
y=z;
z= mod(x,y);
END;
put y;
run;
⒊直到型循环
直到型循环的格式:
DO UNTIL (循环退出条件);
循环体语句……
END;
程序先判断循环退出条件是否成立,成立则结束循环,否则继续。例:
data;
n=0;
do until (n=5);
n+1;
put n=;
end;
run;
麻烦解释下sas语句time=_n_
_n_ 是一个变量,如果在数据集中,则它通常是运行代码sas自动生成的系统变量
sas如何写赋值循环
SAS循环语句
循环语句:
SAS中的循环可分为DO、DO-WHILE、DO-UNTIL三种循环形式
a) DO循环
基本格式:
DO 循环变量 = 初值 TO 终值 BY 步长
→ 循环语句块
END;
上述代码中,首先为循环变量赋值为其初值,然后执行循环体语句块,每执行
第 1 页
重庆 教师编制考试都考什么?最新动态/核心考点辅导
山香网校教师编制考试都考什么专项提搜数升+习题实战+冲刺点睛+面试指导,专业讲师辅导,把握考情,全程跟踪辅导,教师编制考试都考什么为全国广大考生提供教师培训一站式服务,
点击立即咨询,了解更多详情
咨询
河南山香教育咨询有.. 广告
一次按照循环变量的步长,对循环变量的值做出改变,当循环变量的值超过终值后,将终止循环。
示例:
DATA;
DO I=1 TO 10 BY 1; /*计算1~10内各个数的平方,并输出*/
X=I*I;
PUT X;
END;
RUN;
第 2 页
结果如下:
b) DO-WHILE循环
通过条件控制程序的执行,当满足WHILE语句后的条件时,将执行循环体语句块,否则退出循环。其基本的调用格式为:
DO WHILE(循环继续条件);
循环体语句块;
第 3 页
END;
示例:
data;
x=20; /*为变量x赋值*/
do while(x0); /*如果x的值大于0则执行循环*/
x=x-1; /*循环语句*/
end;
put x; /*循环结束后输出变量x的值*/
run;
第 4 页
NOTE: 数据集 WORK.DATA 有 1 个观测和 1 个变量。
NOTE: “DATA 语句”所用时间(总处理时间):
实际时间 0.03 秒
CPU 时间 0.03 秒
c) DO-UNTIL循环
用于根据循环的终止条件完成循环的终止,当循环的终止条件不满足时,扒旦执行循环体语句,否则退出循环。
DO UNTIL(循环终止条件);
循环体语句块;
第 5 页
END;
示例:
data;
x=3; /*为变量x赋值*/
do until(x100); /*执行循环操作,直到变量x的值大于100退出循环*/
x=x*2;
end;
put x; /*循环结束后输出变量x的值*/
run;
第 6 页
结果日志:
192
数据集 WORK.DATA6 有 1 个观测和 1 个变量。春漏扰
第 7 页
百度文库
搜索
SAS循环语句
继续阅读本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
页数说明:当前展示页数为百度文库重新排版后结果,原始文档共2页
相关文档
SAS中的SQL语句完全教程
8817阅读
SAS语句简介
6602阅读
SAS编程:SQL过程简介
2823阅读
第六章[SAS过程中常用语句]
3196阅读
查看更多
为您精选
SAS循环语句
会员文档775篇
人气好文
SAS基础语法总结
9293人阅读
SAS:通用语句
1000人阅读
热门TOP
常用sas语句总结
1.3万人阅读
SAS常用语句
7921人阅读
立即开通VIP
SAS循环语句_重庆 老师编制考试_备考辅导_提分技巧_免费试听
SAS循环语句,山香教育老师编制考试专项提升+习题实战+冲刺点睛+面试指导,专业讲师辅导,把握考情,全程跟踪辅导,老师编制考试为全国广大考生提供教师培训一站式服务,
shanxiangjiaoyu.com广告
SAS循环语句_私立学校招聘 包吃住 交五险一金
SAS循环语句,私立学校
SAS的proc model语句应该怎么用
MODEL语句可用在不同的SAS统计过程中,被用来规定分析的模型。尽管MODEL语句扮誉的具体语句形式依赖于使用的具体过程,但MODEL语神春句的一般使用格式为:
MODEL 因变量列表=自变量列表 /选项 ;
MODEL语句在使用时,要说明哪些变量是因变量,哪些变量是自变量。另外,不要把“=”号看作是等号或赋值号的作用。例如:
Model y=x1-x5 ;
自变量x1、x2、x3、x4、x5,因变量厅瞎段y。
Model y1 y2= a b c d
自变量a、b、c、d,因变量有两个y1和y2。
还木有评论哦,快来抢沙发吧~