我有一个变量(HTB),它是一个整数 - 它可以有1或2的值。
我已经做了一些计算,涉及按用户名聚合HTB - 所以我知道用户多久得到一次 1 或 2 响应
因此,生成的数据框显示变量HTB.1
和HTB.2
我想计算每个用户的HTB = 2的百分比,但是这个
results$HTBpercent<-results$HTB.2/(results$HTB.1+results$HTB.2)*100
不起作用(大概是因为它实际上是一个变量)
我该怎么做?
需要按用户名分组,并意识到您可能只有一个 HTB 变量,并且 R 不使用句点作为选择运算符。也许(假设您希望在每个用户 ID 中复制这些百分比):
results$HTBpercent<- with(results, ave( HTB, userID, function(x) 100*sum( x==2)/length(x) ) )
你可能有这样的内容:
df <- aggregate(c(1,1,2,2), list(c(1,2,1,2)), FUN=table)
df
# Group.1 x.1 x.2
#1 1 1 1
#2 2 1 1
。其中df$x
是一个matrix
,比如:
df$x
# 1 2
#[1,] 1 1
#[2,] 1 1
因此
df$perc2 <- df$x[,"2"] / rowSums(df$x)
df
# Group.1 x.1 x.2 perc2
#1 1 1 1 0.5
#2 2 1 1 0.5