
SAS SQL select…into语句创建宏变量巧妙解决问题的总结
今在某SAS交流群看到这样一个问题如下:
有一个数据集a,有三个变量c,b,d(他们在数据集中的顺序也是如此),想新建一个变量var,并添加到b和d中间,怎么做?
我想的代码如下:
/*将原数据集变量名称存放在宏变量中*/
proc sql ;
select name into :names separated by ","
from dictionary.columns
where libname="SASHELP" and memname="CLASS";
quit;
%put &names;
/*解析宏变量,插入新变量名称,在放入宏变量*/
data test;
vars="&names";
vars_new=tranwrd(vars,"Sex","Sex,'newvar' astest");
call symput("new_names",vars_new);
run;
%put &new_names;
/*在原数据集中插入新变量*/
proc sql;
create table test as
select &new_names
from sashelp.class;
quit;
这个问题思路很简单,把原数据集变量组装如宏变量,再按要求修改,再组装到一个宏变量。在实际工作中可能基本不会遇到,如果遇到一般也是采用数据集间的横向合并去解决这个问题。
在这里想说的是,怎么巧妙运用SQL里select…into语句。如果你一直关注本公众号的文章,你会发现在最近的文章里都涉及到该语句的使用,一个文件夹下文件的批量导入、一个EXCEL工作薄中不规则sheet名称的批量导入,逻辑库多个数据集的批量导出、变量的批量处理,数据集的批量合并等等,都巧妙的应用了select…into..语句。
要巧妙运用该语句,有时还需要理解下SAS的dictionary table(字典数据表)的应用。首先需要字典数据表是什么,通过view字典数据表如下可知,通俗的说就是存放数据集基本信息的数据表,这个表包括存放列(columns)、存放数据集名称(memname)和存放数据集所在逻辑库名称(libname)的数据表。
1.查询数据集变量名称 ,如果要把某数据集的变量名称抽提出来就如上述例子;从dictionary.columns里查询name;
2.查询数据集名称 如果要对某逻辑库的不同数据集进行批量,就把该逻辑库的所有数据集名称放入宏变量。就从dictionary.tables.
proc sql;
select memname INTO :memnames
from dictionary.tables
where libname="WORK";
quit;
3.查询逻辑库名称 如果想对不同逻辑库进行操作,将逻辑库名称放入宏变量。
proc sql;
select distinct(libname)
INTO:memnames separated by ","
from dictionary.tables;
quit;
注意的问题:
(1)以上查询也都可以在dictionary.indexes里查询,变量名称、数据集和逻辑库对应名称为name、memname和libname。
(2)变量名称、数据集和逻辑库名称存放形式均为严格的大写。如where libname="WORK";因此在查询时需注意大小写,如果小写需要upcase下。
(3)需要根据宏变量运用的场景选择不同的分隔符,如sas base模块中多个变量间不需要逗号隔开,这时宏变量变量名称存放时分隔符就该是空格,相反在SQL中多个变量并放时,需要逗号作为分隔符,这时需要逗号分隔名称等等,总之首先需要考虑宏变量的运用场景添加合适的分隔符分隔名称。
4.数据集变量数和观测数
proc sql;
select nobs,nvar into:nobs,:nvars
from dictionary.tables
where libname="WORK" and memname="TEST";
quit;
5.跨逻辑库数据集名称 从多个逻辑库里查询数据集,并批量导出。
/*不同逻辑库不同数据集*/
proc sql;
select distinct trim(libname||"."|| memname)
into :libnames separated by " "
from dictionary.indexes;
quit;
%put &libnames;
综上,想怎么操作,就看你的解决问题的思路了。很简单,问题简单化,就是这么简单和任性。
理解了以上问题,在处理批量问题时其实是很简单的。请结合以前发的文章进行理解,当然还有很多别的应用,只要是能想到的,你能把它转化为sas能识别的语言,一切很简单。
2. SAS data步、SQL和宏解决多表(≥3)合并问题
3. 一段宏解决TOPSIS综合评价问题,写文章也就是批量生产的问题
4. Sas应用之解决多个文件数据资源的批量导入问题
5. Sas 数组、宏应用之批量更改变量类型。
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
2025 年,数据如同数字时代的 DNA,编码着人类社会的未来图景,驱动着商业时代的运转。从全球互联网用户每天产生的2.5亿TB数据, ...
2025-06-052025 年,数据如同数字时代的 DNA,编码着人类社会的未来图景,驱动着商业时代的运转。从全球互联网用户每天产生的2.5亿TB数据, ...
2025-05-27CDA数据分析师证书考试体系(更新于2025年05月22日)
2025-05-26解码数据基因:从数字敏感度到逻辑思维 每当看到超市货架上商品的排列变化,你是否会联想到背后的销售数据波动?三年前在零售行 ...
2025-05-23在本文中,我们将探讨 AI 为何能够加速数据分析、如何在每个步骤中实现数据分析自动化以及使用哪些工具。 数据分析中的AI是什么 ...
2025-05-20当数据遇见人生:我的第一个分析项目 记得三年前接手第一个数据分析项目时,我面对Excel里密密麻麻的销售数据手足无措。那些跳动 ...
2025-05-20在数字化运营的时代,企业每天都在产生海量数据:用户点击行为、商品销售记录、广告投放反馈…… 这些数据就像散落的拼图,而相 ...
2025-05-19在当今数字化营销时代,小红书作为国内领先的社交电商平台,其销售数据蕴含着巨大的商业价值。通过对小红书销售数据的深入分析, ...
2025-05-16Excel作为最常用的数据分析工具,有没有什么工具可以帮助我们快速地使用excel表格,只要轻松几步甚至输入几项指令就能搞定呢? ...
2025-05-15数据,如同无形的燃料,驱动着现代社会的运转。从全球互联网用户每天产生的2.5亿TB数据,到制造业的传感器、金融交易 ...
2025-05-15大数据是什么_数据分析师培训 其实,现在的大数据指的并不仅仅是海量数据,更准确而言是对大数据分析的方法。传统的数 ...
2025-05-14CDA持证人简介: 万木,CDA L1持证人,某电商中厂BI工程师 ,5年数据经验1年BI内训师,高级数据分析师,拥有丰富的行业经验。 ...
2025-05-13CDA持证人简介: 王明月 ,CDA 数据分析师二级持证人,2年数据产品工作经验,管理学博士在读。 学习入口:https://edu.cda.cn/g ...
2025-05-12CDA持证人简介: 杨贞玺 ,CDA一级持证人,郑州大学情报学硕士研究生,某上市公司数据分析师。 学习入口:https://edu.cda.cn/g ...
2025-05-09CDA持证人简介 程靖 CDA会员大咖,畅销书《小白学产品》作者,13年顶级互联网公司产品经理相关经验,曾在百度、美团、阿里等 ...
2025-05-07相信很多做数据分析的小伙伴,都接到过一些高阶的数据分析需求,实现的过程需要用到一些数据获取,数据清洗转换,建模方法等,这 ...
2025-05-06以下的文章内容来源于刘静老师的专栏,如果您想阅读专栏《10大业务分析模型突破业务瓶颈》,点击下方链接 https://edu.cda.cn/g ...
2025-04-30CDA持证人简介: 邱立峰 CDA 数据分析师二级持证人,数字化转型专家,数据治理专家,高级数据分析师,拥有丰富的行业经验。 ...
2025-04-29CDA持证人简介: 程靖 CDA会员大咖,畅销书《小白学产品》作者,13年顶级互联网公司产品经理相关经验,曾在百度,美团,阿里等 ...
2025-04-28CDA持证人简介: 居瑜 ,CDA一级持证人国企财务经理,13年财务管理运营经验,在数据分析就业和实践经验方面有着丰富的积累和经 ...
2025-04-27