【问题标题】:Looping over array to create multiple datasets SAS循环数组以创建多个数据集 SAS
【发布时间】:2015-08-26 20:41:12
【问题描述】:

数据集有 4 个变量:

id v1 v2 v3

我想自动创建 3 个数据集,每个数据集有 2 个变量:id 和原始数据集中的 3 个变量之一。我知道我想使用数组,但不确定如何设置宏代码。

需要将此扩展到具有大量变量的数据集。

【问题讨论】:

  • 为什么需要这么多数据集?以垂直格式制作一个数据集怎么样。
  • 如果使用数组,所有列必须是同一类型。所以转置和拆分数据。

标签: sas sas-macro


【解决方案1】:

4 个变量组成 3 个数据集,最简单的方法就是硬编码?

data v1(keep=id v1) v2(keep=id v2) v3(keep=id v3);
set have;
run;

对不起,错过了那部分,这是更新,你是对的,在我的代码中使用了“数组”:

data _null_;
set have;
array var v1-v200; /*suppose they are all numeric*/
length codegen $ 10000;
do over var;
varname=vname(var);
codegen=catx(' ', codegen, catx(' ',varname,'(keep=id',varname,')'));
end;
call execute ('data '||codegen||'; set have;run;');
stop;
run;

【讨论】:

  • 我已经简化了这个问题,解决方案需要扩展到一个有 200 列的数据集。
猜你喜欢
  • 2017-05-09
  • 1970-01-01
  • 1970-01-01
  • 2012-06-13
  • 2015-03-07
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-02-09
相关资源
最近更新 更多