楼主: 百草园Tracy
1765 5

[原创博文] 在数据的match上遇到了麻烦,关于日期距离最近,请大牛指导! [推广有奖]

  • 0关注
  • 0粉丝

硕士生

23%

还不是VIP/贵宾

-

威望
0
论坛币
119 个
通用积分
8.2495
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
2220 点
帖子
106
精华
0
在线时间
91 小时
注册时间
2007-5-18
最后登录
2015-4-12

楼主
百草园Tracy 发表于 2012-8-27 10:32:22 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
要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来说,不知道大家有办法不?谢谢了!
二维码

扫码加我 拉你入群

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

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

关键词:Match ATCH ATC Mat Variables

沙发
ziyenano 发表于 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;
已有 1 人评分学术水平 热心指数 信用等级 收起 理由
百草园Tracy + 1 + 1 + 1 精彩帖子

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

藤椅
百草园Tracy 发表于 2012-8-27 13:07:54
ziyenano 发表于 2012-8-27 11:07
data a;
input
Company $   date:yymmdd10.;
谢谢LS!!!

板凳
百草园Tracy 发表于 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

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

地板
saintchy 发表于 2013-8-6 15:28:11
学习了

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

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2026-1-2 20:15