全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
1728 5
2012-08-27
要match两个表格,已经有公司的名字作为identifier。但是还需要就日期进行match。

但是A表同公司的日期和B表同公司的日期是不相同的。要求A表公司的日期早于B表的,并且选时间距离最近的进行match。

例子:

A 表                                                         
Company   date                   Other variables
001             2008/03/22
001             2009/03/22
002             2008/09/22
002             2009/09/22
002             2010/09/15

B 表                                                         
Company   date                   Other variables
001             2008/05/22
001             2009/05/22
002             2009/01/22
002             2010/01/22
002             2011/01/22

有点难度啊,对LZ来说,不知道大家有办法不?谢谢了!
二维码

扫码加我 拉你入群

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

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

全部回复
2012-8-27 11:07:37
data a;
input
Company $   date:yymmdd10.;
cards;
001             2008/03/22
001             2009/03/22
002             2008/09/22
002             2009/09/22
002             2010/09/15
;
data b;
input  
Company $   date:yymmdd10.;
cards;
001             2008/05/22
001             2009/05/22
002             2009/01/22
002             2010/01/22
002             2011/01/22
;
run;

proc sql;
create table c as
select company,date_a format=yymmdds10.,date_b format=yymmdds10.
from
(select a.company,a.date as date_a,b.date as date_b,abs(intck('day',a.date,b.date)) as interval
from a inner join b
on a.company=b.company
and a.date>b.date)
group by company
having interval=min(interval)
;
quit;
二维码

扫码加我 拉你入群

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

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

2012-8-27 13:07:54
ziyenano 发表于 2012-8-27 11:07
data a;
input
Company $   date:yymmdd10.;
谢谢LS!!!
二维码

扫码加我 拉你入群

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

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

2012-8-27 13:47:28
ziyenano 发表于 2012-8-27 11:07
data a;
input
Company $   date:yymmdd10.;
发现这样的话,最后每个公司只剩下最后一个match。不好意思,我问题没问清楚,最后希望生成的match是这样的:

Company   date                   Other variables     date                   Other variables
001             2008/03/22                              2008/05/22  
001             2009/03/22                              2009/05/22
002             2008/09/22                              2009/01/22
002             2009/09/22                              2010/01/22
002             2010/09/15                              2011/01/22

不知道有没有办法可以做?帖子里程序生成的是这样的:

001    2009/03/22  2008/05/22
002    2010/09/15  2010/01/22
二维码

扫码加我 拉你入群

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

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

2012-8-27 14:10:01
ziyenano 发表于 2012-8-27 11:07
data a;
input
Company $   date:yymmdd10.;
用了你的code,稍微改了下,搞定了,再次感谢高手!
二维码

扫码加我 拉你入群

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

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

2013-8-6 15:28:11
学习了
二维码

扫码加我 拉你入群

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

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

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群