Предполагая, что level
не дублируется в «группе», после группировки по «группе» извлеките «значение», соответствующее уровню «c» (value[level == 'c']
), и используйте его для деления столбец 'value'
library(dplyr)
d %>%
group_by(group) %>%
mutate(value = value/value[level == 'c'])
# A tibble: 12 x 3
# Groups: group [4]
# group level value
# <chr> <chr> <dbl>
# 1 blue a 1.67
# 2 blue b 1.33
# 3 blue c 1
# 4 red a 5
# 5 red b 4
# 6 red c 1
# 7 yellow a 6
# 8 yellow b 5
# 9 yellow c 1
#10 green a 2.75
#11 green b 2.25
#12 green c 1
Или, если есть несколько 'c', используйте match
, чтобы получить индекс первого вхождения 'c'
d %>%
group_by(group) %>%
mutate(value = value/value[match('c', level)])
Или используя base R
d$value <- d$value/with(subset(d, level == 'c'), setNames(value, group)[d$group])
data
d <- structure(list(group = c("blue", "blue", "blue", "red", "red",
"red", "yellow", "yellow", "yellow", "green", "green", "green"
), level = c("a", "b", "c", "a", "b", "c", "a", "b", "c", "a",
"b", "c"), value = c(5, 4, 3, 10, 8, 2, 6, 5, 1, 11, 9, 4)), row.names = c(NA,
-12L), class = c("tbl_df", "tbl", "data.frame"))