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 数组、宏应用之批量更改变量类型。
数据分析咨询请扫描二维码
《Python数据分析极简入门》 第2节 6 Pandas合并连接 在pandas中,有多种方法可以合并和拼接数据。常见的方法包括append()、conc ...
2024-11-24《Python数据分析极简入门》 第2节 5 Pandas数学计算 importpandasaspdd=np.array([[81,&n ...
2024-11-23数据分析涉及多个方面的学习,包括理论知识和实践技能。以下是数据分析需要学习的主要方面: 基础知识: 数据分析的基本概念 ...
2024-11-22数据分析适合在多个单位工作,包括但不限于以下领域: 金融行业:金融行业对数据分析人才的需求非常大,数据分析师可以从事经 ...
2024-11-22数据分析是一种涉及从大量数据中提取有用信息和洞察力的过程。其工作内容主要包括以下几个方面: 数据收集与整理:数据分析师 ...
2024-11-22数据分析师需要掌握多种技能,以确保能够有效地处理和分析数据,并为业务决策提供支持。以下是数据分析师需要掌握的主要技能: ...
2024-11-22数据开发和数据分析是两个密切相关但又有所区别的领域。以下是它们的主要区别: 定义和目标: 数据开发:数据开发涉及数据的 ...
2024-11-22数据架构师是负责设计和管理企业数据架构的关键角色,其职责涵盖了多个方面,包括数据治理、数据模型设计、数据仓库构建、数据安 ...
2024-11-22数据分析师需要具备一系列技能,以确保能够有效地处理、分析和解释数据,从而支持决策制定。以下是数据分析师所需的关键技能: ...
2024-11-22数据分析师需要具备一系列技能,以确保能够有效地处理、分析和解释数据,从而支持决策制定。以下是数据分析师所需的关键技能: ...
2024-11-22数据分析师需要具备一系列的技能和能力,以确保能够有效地处理、分析和解释数据,从而支持业务决策。以下是数据分析师所需的主要 ...
2024-11-22需求持续增长 - 未来数据分析师需求将持续上升,企业对数据驱动决策的依赖加深。 - 预测到2025年,中国将需要高达220万的数据人 ...
2024-11-22《Python数据分析极简入门》 第2节 4 Pandas条件查询 在pandas中,可以使用条件筛选来选择满足特定条件的数据 importpanda ...
2024-11-22数据分析师的工作内容涉及多个方面,主要包括数据的收集、整理、分析和可视化,以支持商业决策和问题解决。以下是数据分析师的一 ...
2024-11-21数据分析师必须掌握的技能可以从多个方面进行归纳和总结。以下是数据分析师需要具备的主要技能: 统计学基础:数据分析师需要 ...
2024-11-21数据分析入门的难易程度因人而异,总体来看,入门并不算特别困难,但需要一定的学习和实践积累。 入门难度:数据分析入门相对 ...
2024-11-21数据分析是一项通过收集、整理和解释数据来发现有用信息的过程,它在现代社会中具有广泛的应用和重要性。数据分析能够帮助人们更 ...
2024-11-21数据分析行业正在迅速发展,随着技术的不断进步和数据量的爆炸式增长,企业对数据分析人才的需求也与日俱增。本文将探讨数据分析 ...
2024-11-21数据分析的常用方法包括多种技术,每种方法都有其特定的应用场景和优势。以下是几种常见的数据分析方法: 对比分析法:通过比 ...
2024-11-21企业数字化转型是指企业利用数字技术对其业务进行改造和升级,以实现提高效率、降低成本、创新业务模式等目标的过程。这一过程不 ...
2024-11-21