Si vous souhaitez supprimer les colonnes par référence et éviter la copie interne associée, data.frames
vous pouvez utiliser le data.table
package et la fonction:=
Vous pouvez passer un nom de vecteur de caractères sur le côté gauche de l' :=
opérateur et NULL
comme 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]
Si vous souhaitez prédéfinir les noms en tant que vecteur de caractères en dehors de l'appel à [
, encapsulez le nom de l'objet dans ()
ou {}
pour forcer le LHS à être évalué dans la portée appelante et non en tant que nom dans la portée de 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.
Vous pouvez également utiliser set
, ce qui évite la surcharge de [.data.table
, et travaille aussi pour 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)
, et à la place, nous devons faire ces contournements compliqués?