gpt4 book ai didi

SAS:通过查找表中的动态列合并/连接数据集

转载 作者:行者123 更新时间:2023-12-04 21:56:01 25 4
gpt4 key购买 nike

我想将 sas 数据集与查找表连接起来,但是连接的列/键是查找表中的一个值

数据集:table4

             ID  lev1   lev2   lev3   lev4  lev5
1 12548 14589 85652 45896 45889
2 12548 14589 85652 45896 45890
3 12548 14547 85685 45845 45825
4 66588 24647 55255 30895 15764

查表:

           context   table_name column operator value
extract table1 col1 equals xyd
asset table2 var1 equals 11111
asset table2 var2 equals 25858
prod table3 x1 equals 87999
unprod table4 lev2 equals 14589
unprod table4 lev2 equals 14589
unprod table4 lev3 equals 55255

现在我想将 table4 与查找表连接起来,但它只能用于字段 lev2 和 lev3(它是动态的,因此将来可能会更改,所以不想在其中进行硬编码)。

我试过下面的代码,但不想硬编码,因为字段是动态的(将来有人可能会添加 lev4)。

proc sql ;
create table want as
select ID
from table4 as a
inner join lookup as b
on a.lev2 = input(value,12.) or a.lev3=input(value,12.)
where Context="unprod";
quit;

提前致谢。

最佳答案

这看起来不像一个查找表。这似乎是一套规则。您可以使用它来生成代码。让我们通过使表格包含实际代码而不是三列来简化该过程。但您可以轻松编写代码,将当前格式转换为代码字符串。

data rules ;
infile cards truncover ;
input context $ table_name $ rule $100. ;
cards;
extract table1 col1 = xyd
asset table2 var1 = 11111
asset table2 var2 = 25858
prod table3 x1 = 87999
unprod table4 lev2 = 14589
unprod table4 lev2 = 14589
unprod table4 lev3 = 55255
;

所以现在看起来您想要采用具有特定值 CONTEXT 的规则,并使用它从 TABLE_NAME 中命名的数据集生成新数据集。不确定要为生成的表使用什么名称,或者在同一“上下文”中提到多个表时要做什么。

%let context=unprod ;

filename code temp;
data _null_;
set rules ;
where context=symget('context');
by table_name ;
file code ;
if first.table_name then table_no+1;
if first.table_name then put
'data want' table_no ';'
/ ' set ' table_name ';'
/ ' where 1=0'
;
put ' or (' rule ')' ;
if last.table_name then put
';'
/ 'run;'
;
run;

%include code / source2 ;

这导致代码如下:

130  +data want1 ;
131 + set table4 ;
132 + where 1=0
133 + or (lev2 = 14589 )
134 + or (lev2 = 14589 )
135 + or (lev3 = 55255 )
136 +;
137 +run;

NOTE: There were 3 observations read from the data set WORK.TABLE4.
WHERE (lev2=14589) or (lev3=55255);
NOTE: The data set WORK.WANT1 has 3 observations and 6 variables.

关于SAS:通过查找表中的动态列合并/连接数据集,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49808358/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com