楼主: 人生海海
5185 16

求助如何逐一提取数据集中的日期变量作为下一段程序的宏变量&date [推广有奖]

  • 0关注
  • 0粉丝

硕士生

32%

还不是VIP/贵宾

-

威望
0
论坛币
360 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
1722 点
帖子
81
精华
0
在线时间
181 小时
注册时间
2005-6-15
最后登录
2014-8-21

楼主
人生海海 发表于 2010-5-26 17:09:38 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
请教各位高手,如何逐一提取下列数据集a中的日期变量,

12009-1-6
22009-1-15
32009-1-25
42009-2-11
52009-2-21
62009-2-29
72009-3-5
82009-3-15
92009-3-21
102009-5-15


       作为下一段程序的宏变量&date,以运算获得一批数据集?

data b;
set c;
if date<=&date;
run;

        非常感谢!
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:日期变量 date 数据集 ATE Data 数据 程序 变量 amp date

回帖推荐

luijb 发表于9楼  查看完整内容

data raw; input id rq yymmdd10.; cards; 1 2009-1-6 2 2009-1-15 3 2009-1-25 4 2009-2-11 5 2009-2-21 6 2009-2-28 7 2009-3-5 8 2009-3-15 9 2009-3-21 10 2009-5-15 ; run; data rq; input id rq yymmdd10.; name=trim('rq')||trim(put(rq,$5.)); cards; 1 2009-1-6 2 2009-1-15 3 2009-1-25 4 2009-2-11 5 2009-2-21 6 2009-2-28 7 2009-3-5 8 2009-3-15 9 2009-3-21 10 200 ...

crackman 发表于4楼  查看完整内容

call symput("date"||left(_n_),date); %put date1=&date1; %put date2=&date2. or proc sql noprint; select date into:date separated by " " from dataset; quit; date=scan(date,1," ");

本帖被以下文库推荐

沙发
pccbanboo11 在职认证  发表于 2010-5-26 17:45:19
实在是看不懂

藤椅
人生海海 发表于 2010-5-26 17:49:11
请问楼上哪里看不懂呢?

板凳
crackman 发表于 2010-5-26 17:55:59
call symput("date"||left(_n_),date);
%put  date1=&date1;
%put date2=&date2.



or


proc sql noprint;
select date into:date separated by " " from dataset;
quit;
date=scan(date,1," ");
已有 1 人评分经验 论坛币 收起 理由
bakoll + 3 + 3 精彩帖子

总评分: 经验 + 3  论坛币 + 3   查看全部评分

报纸
人生海海 发表于 2010-5-26 18:01:55
数据集a中的日期条目数是不确定的,可能上千条,所以最后的数据集数目也可能上千个。

地板
crackman 发表于 2010-5-26 18:30:25
用一个宏来做就是了

7
人生海海 发表于 2010-5-27 13:03:14
请问楼上如何做啊,拜谢了!

8
pobel 在职认证  发表于 2010-5-27 13:48:29
%macro result(ds_in=
              ,date_var=
              ,ds_out=);

data temp;
     set &ds_in;
         format &date_var;
run;

%let ds_out=&ds_out;

        proc sql noprint;
             select &date_var into :date_mvar separated by "*"
                   from temp;
        quit;

%let date_num=&sqlobs;
   data
     %do i=1 %to &date_num;
          &ds_out&i
         %end;
         ;
         set temp;
         %do i=1 %to &date_num;
             %let dt_value&i=%scan(&date_mvar,&i,*);
             if &date_var<=&&dt_value&i then output &ds_out&i;
         %end;
run;

%mend;

options mprint;
%result(ds_in=sashelp.citiyr
        ,date_var=date
        ,ds_out=haha )
已有 2 人评分学术水平 热心指数 收起 理由
soporaeternus + 1 + 1 学习了
crackman + 1 精彩帖子

总评分: 学术水平 + 1  热心指数 + 2   查看全部评分

9
luijb 在职认证  发表于 2010-5-27 16:52:30
data raw;
input id rq yymmdd10.;
cards;
1 2009-1-6
2 2009-1-15
3 2009-1-25
4 2009-2-11
5 2009-2-21
6 2009-2-28
7 2009-3-5
8 2009-3-15
9 2009-3-21
10 2009-5-15
;
run;
data rq;
input id rq yymmdd10.;
name=trim('rq')||trim(put(rq,$5.));
cards;
1 2009-1-6
2 2009-1-15
3 2009-1-25
4 2009-2-11
5 2009-2-21
6 2009-2-28
7 2009-3-5
8 2009-3-15
9 2009-3-21
10 2009-5-15
;
run;
data _null_;
   set rq;
   by rq;
   if first.rq then call execute('data '||name||";set raw;where rq<"||rq||";run;");
run;

我想我的程序肯定能满足你的要求,并且很关键的是,我的程序很简洁啊,只有区区五行。而且支持重复日期。
已有 1 人评分学术水平 热心指数 收起 理由
crackman + 1 + 1 精彩帖子

总评分: 学术水平 + 1  热心指数 + 1   查看全部评分

西格玛临床统计服务工作室http://www.sigma-stat.com/,luijb@163.com

10
人生海海 发表于 2010-5-28 14:26:28
谢谢楼上,但是我一定要取到宏变量&date,因为此变量还要在以下的程序中多次使用的。
请教如何处理?非常感谢!

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-29 12:25