Если вы хотите удалить столбцы по ссылке и избежать внутреннего копирования, связанного с этим, data.framesвы можете использовать data.tableпакет и функцию:=
Вы можете передать имена векторных символов в левую часть :=оператора и NULLкак RHS.
library(data.table)
df <- data.frame(a=1:10, b=1:10, c=1:10, d=1:10)
DT <- data.table(df)
# or more simply DT <- data.table(a=1:10, b=1:10, c=1:10, d=1:10) #
DT[, c('a','b') := NULL]
Если вы хотите предварительно определить имена как символьный вектор вне вызова [, оберните имя объекта в ()или {}заставьте LHS быть оцененным в вызывающей области, а не как имя в пределах области DT.
del <- c('a','b')
DT <- data.table(a=1:10, b=1:10, c=1:10, d=1:10)
DT[, (del) := NULL]
DT <- <- data.table(a=1:10, b=1:10, c=1:10, d=1:10)
DT[, {del} := NULL]
# force or `c` would also work.
Вы также можете использовать set, что позволяет избежать накладных расходов [.data.table, а также работает на data.frames!
df <- data.frame(a=1:10, b=1:10, c=1:10, d=1:10)
DT <- data.table(df)
# drop `a` from df (no copying involved)
set(df, j = 'a', value = NULL)
# drop `b` from DT (no copying involved)
set(DT, j = 'b', value = NULL)
df#drop(var_name), и вместо этого нам нужно сделать эти сложные обходные пути?