全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
11454 6
2012-05-10
data test;
input region $ state $ month monyy5. headcnt expenses revenue;
format month monyy5.;
cards;
EASTERN VA FEB78 10 7800 15500
SOUTHERN FL MAR78 9 9800 13500
SOUTHERN GA JAN78 5 2000 8000
NORTHERN MA MAR78 3 1500 1000
SOUTHERN FL FEB78 10 8500 11000
NORTHERN NY MAR78 5 6000 5000
EASTERN VA MAR78 11 8200 16600
PLAINS NM MAR78 2 1350 500
SOUTHERN FL JAN78 10 8000 10000
NORTHERN NY FEB78 4 3000 4000
SOUTHERN GA FEB78 7 1200 6000
;
run;

%macro test;
    data ttest;
        %let dsid=%sysfunc(open(test));
        %if &dsid gt 0 %then %do;
            %let nobs=%sysfunc(attrn(&dsid,nobs));
            %do i=1 %to &nobs;
                %let rc=%sysfunc(fetchobs(&dsid,&i));
                %let varnume=%sysfunc(varnum(&dsid,region));
                %let variable=%sysfunc(getvarc(&dsid,&varnume));
                %put "&dsid";
                %put "&nobs";
                %put "&rc";
                %put "&varnume";
                %put "&variable";
                %put *****************;
            %end;
            %let rc=%sysfunc(close(&dsid));
        %end;
    run;
%mend test;
%test

我想问一下
%let rc=%sysfunc(fetchobs(&dsid,&i));
%let varnume=%sysfunc(varnum(&dsid,region));
%let variable=%sysfunc(getvarc(&dsid,&varnume));
具体什么含义。
二维码

扫码加我 拉你入群

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

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

全部回复
2012-5-10 22:30:29
                %let rc=%sysfunc(fetchobs(&dsid,&i));
                %let varnume=%sysfunc(varnum(&dsid,region));
                %let variable=%sysfunc(getvarc(&dsid,&varnume));
具体代表什么意思???
二维码

扫码加我 拉你入群

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

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

2012-5-10 22:48:32
wodematlab 发表于 2012-5-10 22:30
%let rc=%sysfunc(fetchobs(&dsid,&i));
                %let varnume=%sysfunc(varnum( ...
有点看不懂
二维码

扫码加我 拉你入群

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

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

2012-5-11 10:07:03
%let rc=%sysfunc(fetchobs(&dsid,&i));/*读取指定的第i条记录,若成功则返回0,返回-1表示已读取完所以记录*/
%let varnume=%sysfunc(varnum(&dsid,region));/*varnum是返回变量region的位置,在这变量region是第一列,所以varnume的值为1*/
%let variable=%sysfunc(getvarc(&dsid,&varnume));/*getvarc是将第i条记录的第1(因为varnume的值为1)个变量的值赋给variable,此外getvarc是针对读取字符型的变量,getvarn是针对读取数值型的变量*/
二维码

扫码加我 拉你入群

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

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

2012-5-11 22:38:55
可~乐 发表于 2012-5-11 10:07
%let rc=%sysfunc(fetchobs(&dsid,&i));/*读取指定的第i条记录,若成功则返回0,返回-1表示已读取完所以记录 ...
非常感谢
二维码

扫码加我 拉你入群

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

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

2012-5-12 04:03:19
good to learn, it is easy to get lost.
二维码

扫码加我 拉你入群

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

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

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

说点什么

分享

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