relrec调取对应domain数据

/*sdtm为需要调用变量的domain;relid为两个domain组合做成的relid需要确认顺序;var为需要调用的变量;adam为正在做的adam数据集*/
%macro relrec(sdtm=,relid=,var=,adam= );
data rel;
	set sdtm.relrec;
	where find(relid,&relid.) ;
	IDVARVAL_=input(IDVARVAL,best.);
proc sort;by usubjid relid;
run;
proc transpose data=rel out=rel1;
	by usubjid relid;
	id idvar  ;
	var idvarval_;
run; 
data rel2;
	merge rel1(in=a ) sdtm.&sdtm.;
	by usubjid &sdtm.seq;
	if a;
	keep usubjid aeseq &var.;
	proc sort;by usubjid &adam.seq;
run;
data rel3;
	set rel2;
	retain ord;
	by usubjid &adam.seq;
	if first.&adam.seq then ord=1;
		else ord+1;
	call symputx('maxn',max(ord));
run;
%put &maxn.;
proc transpose data=rel3 out=rel4 prefix=col;
	by usubjid &adam.seq;
	id ord;
	var &var.;
run;
data rel_;
	length RELAE $200;
	set rel4;
	array rel[&maxn.] col:;
	do i= 1 to &maxn.;
	if rel[i] ne "" and i>1 then rel[i]="/"||rel[i];
	if rel[i] ne "" then RELAE=compress(RELAE||strip(rel[i]));
	end;
run;
%mend;
%relrec(sdtm=cm,relid="CMAE",var=cmtrt,adam=ae);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值