楼主: yukai08008
1237 0

[学习分享] 分类变量水平提取SAS宏代码_Andy的原创帖17 [推广有奖]

  • 2关注
  • 17粉丝

讲师

2%

还不是VIP/贵宾

-

威望
0
论坛币
2176 个
通用积分
3.0600
学术水平
10 点
热心指数
7 点
信用等级
7 点
经验
5915 点
帖子
120
精华
0
在线时间
556 小时
注册时间
2012-11-28
最后登录
2022-4-11

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币

根据贴15的宏可以挑出适合用作分类变量的变量,以下则利用前步生成的set_des数据集以及分类指示变量cls_indi来提取出
所有对应的变量水平,存放在var_class数据集中。(为了避免后续变量大小写的问题,全部把变量名称转化为小写)
生成的临时数据集全部以_templ 开头,如果这个过程可能会生成大量的临时数据集可以及时清空。

/*析取变量的水平值

输入数据集为 ins1

默认经过了set_des处理,用cls_indi指示分类变量

*/

%macro vlevel(ins1,ins=set_des,indi=cls_indi);

/*不能使用noprint,否则sql自动宏变量有问题*/

proc sql;

select name

from &ins

where &indi;

quit;

/*2对自动宏变量进行二次赋值*/

%letrows=&sqlobs;

/*3sql给每一个变量名称映射到宏变量中*/

proc sql noprint;

select name into :var1-:var&rows

from &ins

where &indi;

quit;

/*4进行do循环取出各水平,拼成数据集*/

%do i=1 %to &rows;

proc sortdata=&ins1(keep=&&var&i) out=lname nodupkey;

by &&var&i;

run;

data %sysfunc(cats(_templ,&i));

length level $ 15;

set lname;

varname=lowcase(symget('var'||left(&i)));

level=left(&&var&i)||'';

drop &&var&i;

run;

%end;

/*5把所有变量及其水平拼接到一个数据集中*/

data var_class;

set _templ1-_templ&rows;

run;

%mend;


二维码

扫码加我 拉你入群

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

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

关键词:Andy 分类变量 SAS宏 proc sql NODUPKEY

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

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-4-23 21:12