楼主: ywb0314
3910 0

[原创博文] 转帖-取SAS数据集的变量名并赋给宏变量 [推广有奖]

  • 8关注
  • 3粉丝

讲师

32%

还不是VIP/贵宾

-

威望
0
论坛币
1244 个
通用积分
12.3563
学术水平
3 点
热心指数
2 点
信用等级
2 点
经验
57175 点
帖子
542
精华
0
在线时间
438 小时
注册时间
2010-2-8
最后登录
2019-4-16

楼主
ywb0314 发表于 2011-11-7 10:37:03 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
取SAS数据集的变量名并赋给宏变量 对一个数据集的变量进行分析,至少需要变量名,对吧。如果变量少,自已逐个输入也没问题,所谓忍一忍就和谐了。如果变量多呢,就无法忍受了--一个个地敲进去,不但麻烦,且易出错。解决之道有三种。
其一是读取表的dictionary.columns.Dictionary表里保存着库名及其成员的名字。以sashelp里的表class为例。
proc sql;
create table vars as
   select varnum,name
   from dictionary.columns
   where memname='CLASS';
quit;
其中varnum表示是第几个变量,name表示变量名。值得提醒的是,Dictionary里是以大写字母的形式保存表名。所以这里须要写CLASS。
其二是读取SASHELP.VCOLUMN。以数据步读取的形式如下
data vars1;
set sashelp.vcolumn;
where memname='CLASS';
keep varnum name;
run;
其三是利用过程proc contents。这个要来得比读取dictionary和sashelp.vcolumn灵活。
data vars1;
set sashelp.vcolumn;
where memname='CLASS';
keep varnum name;
run;
如果需要将变量名赋给一个宏变量,以空格隔开。其例如下
proc contents data=sashelp.class
out=vars3(keep=varnum name)
     noprint;
run;
proc sql noprint;
select distinct name
     into :classname separated by ' '
     from vars3
     order by varnum;
quit;
可以用%put &classname;察看其宏变量。得到结果
Name Sex Age Height Weight
当然有时并不想所有的变量都赋给这个宏变量。比如只想取出第1个和第2个变量给宏变量。当然也好解决。
proc sql noprint;
select distinct name
     into :classname separated by ' '
     from vars3
     where varnum in (1,2)
     order by varnum;
quit;
注意加了行where varnum in (1,2).或者
proc contents data=sashelp.class(keep=Name Sex)
out=vars4(keep=varnum name)
     noprint;
run;
proc sql noprint;
select distinct name
     into :classname separated by ' '
     from vars4     
     order by varnum;
quit;
%put &classname;
也是一样的。


原文出处http://www.cnblogs.com/zgw21cn/archive/2009/02/20/1395211.html
二维码

扫码加我 拉你入群

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

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

关键词:sas数据集 数据集 Dictionary proc sql separate

已有 1 人评分热心指数 信用等级 收起 理由
yugao1986 + 1 + 1 奖励积极上传好的资料

总评分: 热心指数 + 1  信用等级 + 1   查看全部评分

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-9 12:38