Я пытаюсь добавить несколько наборов столбцов вместе.
Пример df:
df <- data.frame(
key = 1:5,
ab0 = c(1,0,0,0,1),
ab1 = c(0,2,1,0,0),
ab5 = c(1,0,0,0,1),
bc0 = c(0,1,0,2,0),
bc1 = c(2,0,0,0,0),
bc5 = c(0,2,1,0,1),
df0 = c(0,0,0,1,0),
df1 = c(1,0,3,0,0),
df5 = c(1,0,0,0,6)
)
Предоставление мне:
key ab0 ab1 ab5 bc0 bc1 bc5 df0 df1 df5
1 1 1 0 1 0 2 0 0 1 1
2 2 0 2 0 1 0 2 0 0 0
3 3 0 1 0 0 0 1 0 3 0
4 4 0 0 0 2 0 0 1 0 0
5 5 1 0 1 0 0 1 0 0 6
Я хочу добавить все наборы столбцов с 0 и 5 в них вместе и поместить их в0 столбец.
Таким образом, конечный результат будет:
key ab0 ab1 ab5 bc0 bc1 bc5 df0 df1 df5
1 1 2 0 1 0 2 0 0 1 1
2 2 0 2 0 3 0 2 0 0 0
3 3 0 1 0 1 0 1 0 3 0
4 4 0 0 0 2 0 0 2 0 0
5 5 2 0 1 1 0 1 0 0 6
Я мог бы добавить столбцы вместе, используя 3 строки:
df$ab0 <- df$ab0 + df$ab5
df$bc0 <- df$bc0 + df$bc5
df$df0 <- df$df0 + df$df5
Но мой реальный пример имеет болеесто столбцов, поэтому я бы хотел перебрать их и использовать apply.
Имена столбцов первого набора содержатся в col0, а имена второго набора - в col5.
col0 <- c("ab0","bc0","df0")
col5 <- c("ab5","bc5","df5")
Я создал функцию для добавления столбцов в gether, используя mapply:
fun1 <- function(df,x,y) {
df[,x] <- df[,x] + df[,y]
}
mapply(fun1,df,col0,col5)
Но я получаю ошибку: Ошибка в df [, x]: неверное количество измерений
Мысли