楼主: qcasrl
8590 3

[问答] sas 匹配有重复值的两个数据集,如何实现? [推广有奖]

  • 6关注
  • 0粉丝

博士生

27%

还不是VIP/贵宾

-

威望
0
论坛币
99 个
通用积分
17.8700
学术水平
0 点
热心指数
1 点
信用等级
0 点
经验
503 点
帖子
106
精华
0
在线时间
397 小时
注册时间
2014-1-16
最后登录
2023-12-7

楼主
qcasrl 发表于 2015-8-13 17:57:12 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
sas匹配两个数据集,如果data a 和data b中的可以作为匹配条件的变量均有许多重复值,也有很多缺失值,应当如何处理?

具体点:
如连接两个数据集时,匹配变量为姓名,出生日期

data a 和 b 中 都有许多重名的情况,出生日期也有很多重复的情况。

需要实现目标:a 和b中观测对象的姓名,出生日期相同,他们则可能是同一观测对象,需要对这部分人进行标注。

像这种多对多的情况需要怎么用sas实现?

merge ?proc sql?

为什么我做出来的结果都是姓名为缺失值的观测匹配上了。。。。
匹配之前需要先把缺失值剔除吗?
二维码

扫码加我 拉你入群

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

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

关键词:如何实现 数据集 重复值 proc sql Merge 出生日期 如何 姓名

沙发
xun448122177 发表于 2015-8-13 20:04:21
proc sql;
create table tmp as
select a.*,b.*
from a
left join b
on a.name=b.name and a.birthday=b.birthday
where b.name is not null
;
quit;

藤椅
xun448122177 发表于 2015-8-13 20:06:53
xun448122177 发表于 2015-8-13 20:04
proc sql;
create table tmp as
select a.*,b.*
如果两个表中的重复记录可以去掉的话,建议在两表连接之前用proc sort data=a nodupkey; by name; run;  对数据去重。

板凳
qiuyishoudai 发表于 2015-8-13 22:07:57
不了解,希望楼主早点解决问题。

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

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