全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
3699 4
2019-03-11
具体问题是这样的。楼主写了一段proc sql的代码,其中有个数据集中的变量命名大概是这样的:var1,var2,var3,...,一直到var10。在sql中选取变量直接写就是
proc sql;
select var1, var2, var3, var4, var5, var6, var7, var8, var9, var10
from a;
quit;
(当然这只是最简单的sql代码,主要用于说明问题)。上面var1一直到var10是有规律可循的,有的时候可能是var_01 var1这种情况,想问一下有没有类似于通配符(比如说*是通配符),直接select var* 就可以把所有var作为前缀的变量给选取呢?

谢谢各位大神!!!
二维码

扫码加我 拉你入群

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

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

全部回复
2019-3-11 22:40:48
复制代码
二维码

扫码加我 拉你入群

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

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

2019-3-13 20:05:15
whymath 发表于 2019-3-11 22:40
谢谢您的回答,可能我问得还不够具体,我的意思主要是针对在sql中是否有通配符的用法。谢谢。而且不是用在 where-like中筛选条件的那种,是用来简化变量查询和检索,或者说是批量选中变量(更具体可以看第一楼问题)。求解答,谢谢!
二维码

扫码加我 拉你入群

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

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

2019-3-13 20:47:05
凡尘梦1990 发表于 2019-3-13 20:05
谢谢您的回答,可能我问得还不够具体,我的意思主要是针对在sql中是否有通配符的用法。谢谢。而且不是用在 ...
您好。
答案是没有。
不过或许宏变量可以帮你的忙。
二维码

扫码加我 拉你入群

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

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

2019-3-21 14:10:31

做了个demo程序,不知道是不是满足你的问题。


data a;

var1=1;

var2=2;

var3=2;

var4=2;

var5=2;

var6=2;

var7=2;

var8=2;

var9=2;

var10=2;

oths1=0;

oths2=0;

run;




proc sql;

select name into :vname separated by ',' from sashelp.vcolumn

where libname = 'WORK'

  and memname = 'A'

  and name like 'var%'

;quit;


%put &vname;



proc sql;

select &vname

from a;

quit;


二维码

扫码加我 拉你入群

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

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

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

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