京公网安备 11010802034615号
经营许可证编号:京B2-20210330
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
在MySQL数据库优化中,分区表是处理海量数据的核心手段——通过将大表按分区键(如时间、地域、ID范围)分割为多个独立的小分区 ...
2026-03-19在商业智能与数据可视化领域,同比、环比增长率是分析数据变化趋势的核心指标——同比(YoY)聚焦“长期趋势”,通过当前周期与 ...
2026-03-19在数据分析与建模领域,流传着一句行业共识:“数据决定上限,特征决定下限”。对CDA(Certified Data Analyst)数据分析师而言 ...
2026-03-19机器学习算法工程的核心价值,在于将理论算法转化为可落地、可复用、高可靠的工程化解决方案,解决实际业务中的痛点问题。不同于 ...
2026-03-18在动态系统状态估计与目标跟踪领域,高精度、高鲁棒性的状态感知是机器人导航、自动驾驶、工业控制、目标检测等场景的核心需求。 ...
2026-03-18“垃圾数据进,垃圾结果出”,这是数据分析领域的黄金法则,更是CDA(Certified Data Analyst)数据分析师日常工作中时刻恪守的 ...
2026-03-18在机器学习建模中,决策树模型因其结构直观、易于理解、无需复杂数据预处理等优势,成为分类与回归任务的首选工具之一。而变量重 ...
2026-03-17在数据分析中,卡方检验是一类基于卡方分布的假设检验方法,核心用于分析分类变量之间的关联关系或实际观测分布与理论期望分布的 ...
2026-03-17在数字化转型的浪潮中,企业积累的数据日益庞大且分散——用户数据散落在注册系统、APP日志、客服记录中,订单数据分散在交易平 ...
2026-03-17在数字化时代,数据分析已成为企业决策、业务优化、增长突破的核心支撑,从数据仓库搭建(如维度表与事实表的设计)、数据采集清 ...
2026-03-16在数据仓库建设、数据分析(尤其是用户行为分析、业务指标分析)的实践中,维度表与事实表是两大核心组件,二者相互依存、缺一不 ...
2026-03-16数据是CDA(Certified Data Analyst)数据分析师开展一切工作的核心载体,而数据读取作为数据生命周期的关键环节,是连接原始数 ...
2026-03-16在用户行为分析实践中,很多从业者会陷入一个核心误区:过度关注“当前数据的分析结果”,却忽视了结果的“泛化能力”——即分析 ...
2026-03-13在数字经济时代,用户的每一次点击、浏览、停留、转化,都在传递着真实的需求信号。用户行为分析,本质上是通过收集、整理、挖掘 ...
2026-03-13在金融、零售、互联网等数据密集型行业,量化策略已成为企业挖掘商业价值、提升决策效率、控制经营风险的核心工具。而CDA(Certi ...
2026-03-13在机器学习建模体系中,随机森林作为集成学习的经典算法,凭借高精度、抗过拟合、适配多场景、可解释性强的核心优势,成为分类、 ...
2026-03-12在机器学习建模过程中,“哪些特征对预测结果影响最大?”“如何筛选核心特征、剔除冗余信息?”是从业者最常面临的核心问题。随 ...
2026-03-12在数字化转型深度渗透的今天,企业管理已从“经验驱动”全面转向“数据驱动”,数据思维成为企业高质量发展的核心竞争力,而CDA ...
2026-03-12在数字经济飞速发展的今天,数据分析已从“辅助工具”升级为“核心竞争力”,渗透到商业、科技、民生、金融等各个领域。无论是全 ...
2026-03-11上市公司财务报表是反映企业经营状况、盈利能力、偿债能力的核心数据载体,是投资者决策、研究者分析、从业者复盘的重要依据。16 ...
2026-03-11