全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
6582 2
2010-08-23
现有以下数据
data a;
input smoking frq wgt;
cards;
1 3 2.28
1 2 3.50
0 1 2.67
0 2 0.56
;
run;

其中:smoking代表吸烟,frq为频数,wgt为抽样所导致的个体权重,现在想计算吸烟率
问题是:
1、 采用proc freq 不能同时加权频数权重和抽样权重;

2、 采用proc tablutale,加权(weight)只能是对分析变量(var)有用,对分类变量(class)不起作用,不清楚是什么原因,也即下面程序中,将var smoking换成 class smoking,结果就会不一样,实际上也是不能同时加权频数权重和抽样权重。
proc tabulate data=a format=12.6 out=a1;
var smoking;
table smoking all/ rts=8;
freq frq;
weight wgt;
run;

如果谁知道怎么解决这个问题,希望能交流一下,非常感谢,^_^
二维码

扫码加我 拉你入群

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

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

全部回复
2010-8-28 09:42:34
moonstone 发表于 2010-8-23 22:59
现有以下数据
data a;
input smoking frq wgt;
cards;
1 3 2.28
1 2 3.50
0 1 2.67
0 2 0.56
;
run;

其中:smoking代表吸烟,frq为频数,wgt为抽样所导致的个体权重,现在想计算吸烟率
问题是:
1、 采用proc freq 不能同时加权频数权重和抽样权重;

2、 采用proc tablutale,加权(weight)只能是对分析变量(var)有用,对分类变量(class)不起作用,不清楚是什么原因,也即下面程序中,将var smoking换成 class smoking,结果就会不一样,实际上也是不能同时加权频数权重和抽样权重。
proc tabulate data=a format=12.6 out=a1;
var smoking;
table smoking all/ rts=8;
freq frq;
weight wgt;
run;

如果谁知道怎么解决这个问题,希望能交流一下,非常感谢,^_^
There is a simple trick you can do. See example below.

data a;
input smoking frq wgt;
totalweight= frq*wgt;
smoking2=smoking;
cards;
1 3 2.28
1 2 3.50
0 1 2.67
0 2 0.56
;


proc tabulate data=a format=12.6 out=a1;
class smoking2;
var smoking;
table smoking2=' ',smoking all/ rts=8;
*freq frq;
*weight wgt;
weight     totalweight;
run;


proc tabulate data=a format=12.6 out=a1;
class smoking2;
var smoking;
table smoking2=' ',smoking all/ rts=8;
freq frq;
weight wgt;
run;
二维码

扫码加我 拉你入群

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

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

2015-3-9 14:01:16
surveyfreq
二维码

扫码加我 拉你入群

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

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

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

说点什么

分享

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