SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 602|回复: 3
打印 上一主题 下一主题

如何实现下面的想法?急~~

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2009-5-16 15:55:23 | 只看该作者

如何实现下面的想法?急~~

各位大侠,下面这个想法怎么用sas实现呢?A为字符型变量,B为数值型变量,要把相同的A 对应的B加总。下面是简化的例子。

A                B

101           2

002           3

101          3

101           4

104          1

002           10

104          5     

最后要得到下面的数据集:

A           B

101       9

002      13

104       6

我的数据集很大,不同的A有上千种。真不知道怎么做了,急,请大家帮忙,谢谢!
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2009-5-16 22:19:55 | 只看该作者

Re: 如何实现下面的想法?急~~

data old;
input A B;
datalines;
101 2
002 3
101 3
101 4
104 1
002 10
104 5
;
run;
proc sql;
create table new as select distinct A,sum(B) as Bsum from old group by A;quit;
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2009-5-18 08:52:01 | 只看该作者

Re: 如何实现下面的想法?急~~

data tem;
   input A $ B;
   cards;
101 2
002 3
101 3
101 4
104 1
002 10
104 5
;
run;

proc summary data=tem nway;
   class A;
   var B;
   output out=out(keep=A B) sum=B;
run;
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
地板
 楼主| 发表于 2009-6-14 22:54:18 | 只看该作者

Re: 如何实现下面的想法?急~~

上面两种方法,都正确,一种是通过SQL,一种是summary,还可以用tabulate的汇总功能
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|小黑屋|手机版|Archiver|SAS中文论坛  

GMT+8, 2026-2-5 15:53 , Processed in 0.279512 second(s), 20 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表