gpt4 book ai didi

r - 计算均值,包括除一个以外的所有因子水平

转载 作者:行者123 更新时间:2023-12-05 01:22:22 25 4
gpt4 key购买 nike

使用数据框 mtcars 我想添加列 qsec_control 计算为所有行的 mean(qsec) 't have the same cyl as the current row (e.g. if cyl == 6, it would take mean(qsec[cyl != 6]))。这个问题感觉有点愚蠢,但我不知道该怎么做。

最佳答案

此解决方案按 cyl 分组,然后使用 dplyr::cur_group_rows() 索引到 mtcars$qsec:

library(dplyr)

mtcars %>%
group_by(cyl) %>%
mutate(qsec_control = mean(
mtcars$qsec[-cur_group_rows()]
)) %>%
ungroup()
# A tibble: 32 × 12
mpg cyl disp hp drat wt qsec vs am gear carb qsec_cont…¹
<dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl>
1 21 6 160 110 3.9 2.62 16.5 0 1 4 4 17.8
2 21 6 160 110 3.9 2.88 17.0 0 1 4 4 17.8
3 22.8 4 108 93 3.85 2.32 18.6 1 1 4 1 17.2
4 21.4 6 258 110 3.08 3.22 19.4 1 0 3 1 17.8
5 18.7 8 360 175 3.15 3.44 17.0 0 0 3 2 18.7
6 18.1 6 225 105 2.76 3.46 20.2 1 0 3 1 17.8
7 14.3 8 360 245 3.21 3.57 15.8 0 0 3 4 18.7
8 24.4 4 147. 62 3.69 3.19 20 1 0 4 2 17.2
9 22.8 4 141. 95 3.92 3.15 22.9 1 0 4 2 17.2
10 19.2 6 168. 123 3.92 3.44 18.3 1 0 4 4 17.8
# … with 22 more rows, and abbreviated variable name ¹​qsec_control

关于r - 计算均值,包括除一个以外的所有因子水平,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/74274971/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com