首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >表(R)将被加权

表(R)将被加权
EN

Stack Overflow用户
提问于 2020-10-06 14:11:38
回答 4查看 2.4K关注 0票数 2

我试图运行交叉表/应急表,但需要通过加权变量对其进行加权。以下是一些样本数据。

代码语言:javascript
复制
set.seed(123)
sex <- sample(c("Male", "Female"), 100, replace = TRUE)
age <- sample(c("0-15", "16-29", "30-44", "45+"), 100, replace = TRUE)
wgt <- sample(c(1:10), 100, replace = TRUE)
df <- data.frame(age,sex, wgt)

我运行这个是为了获得一个常规的交叉表

代码语言:javascript
复制
table(df$sex, df$age)

为了获得加权频率,我尝试了Hmisc包(如果您知道更好的包,请告诉我)

代码语言:javascript
复制
library(Hmisc)
wtd.table(df$sex, df$age, weights=df$wgt)
Error in match.arg(type) : 'arg' must be of length 1

我不知道我哪里出了问题,但它不能运行,所以任何帮助都会很好。或者,如果您知道如何在另一个包中这样做,这可能会更好地分析调查数据,这也将是很好的。在此之前,非常感谢您。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2020-10-06 14:21:29

尝尝这个

代码语言:javascript
复制
GDAtools::wtable(df$sex, df$age, w = df$wgt)

输出

代码语言:javascript
复制
       0-15 16-29 30-44 45+ NA tot
Female   56    73    60  76  0 265
Male     76    99   106  90  0 371
NA        0     0     0   0  0   0
tot     132   172   166 166  0 636

更新

如果您不想安装整个包,以下是您需要的两个基本功能:

瓦特二分态

源它们,您应该能够使用wtable没有任何问题。

票数 2
EN

Stack Overflow用户

发布于 2020-10-06 14:20:37

一个解决方案是按权重重复data.frame的行,然后table结果。

下面重复data.framework的行(只有相关的列):

代码语言:javascript
复制
df[rep(row.names(df), df$wgt), 1:2]

它可以用来得到应急表。

代码语言:javascript
复制
table(df[rep(row.names(df), df$wgt), 1:2])
#       sex
#age     Female Male
#  0-15      56   76
#  16-29     73   99
#  30-44     60  106
#  45+       76   90
票数 2
EN

Stack Overflow用户

发布于 2021-09-03 07:55:29

基数R (以stats为单位)的xtabs正是用于这一点的:

代码语言:javascript
复制
xtabs(wgt ~ age + sex, data=df) 
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64227592

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档