Bu tür bir alt küme ile yapamazsınız $
. Kaynak kodunda ( R/src/main/subset.c
) şunu belirtir:
/ * $ Alt küme operatörü.
Yalnızca ilk argümanı değerlendirdiğimizden emin olmalıyız.
İkincisi, eşleştirilmesi gereken, değerlendirilmemesi gereken bir sembol olacaktır.
* /
İkinci argüman? Ne?! Bunu gerçekleştirmek zorunda $
Ar her şey gibi, (örneğin dahil (
, +
, ^
argüman alır ve değerlendirilir bir fonksiyonudur vs). df$V1
olarak yeniden yazılabilir
`$`(df , V1)
ya da gerçekten
`$`(df , "V1")
Fakat...
`$`(df , paste0("V1") )
... örneğin asla işe yaramayacak, ilk önce ikinci argümanda değerlendirilmesi gereken başka hiçbir şey olmayacak. Asla olmayan bir dizeyi yalnızca değerlendirilmeyen .
Bunun yerine kullanın [
(veya [[
yalnızca tek bir sütunu vektör olarak çıkarmak istiyorsanız).
Örneğin,
var <- "mpg"
#Doesn't work
mtcars$var
#These both work, but note that what they return is different
# the first is a vector, the second is a data.frame
mtcars[[var]]
mtcars[var]
do.call
Çağrıyı oluşturmak için kullanarak döngüler olmadan sıralamayı gerçekleştirebilirsiniz order
. Aşağıda tekrarlanabilir bir örnek verilmiştir:
# set seed for reproducibility
set.seed(123)
df <- data.frame( col1 = sample(5,10,repl=T) , col2 = sample(5,10,repl=T) , col3 = sample(5,10,repl=T) )
# We want to sort by 'col3' then by 'col1'
sort_list <- c("col3","col1")
# Use 'do.call' to call order. Seccond argument in do.call is a list of arguments
# to pass to the first argument, in this case 'order'.
# Since a data.frame is really a list, we just subset the data.frame
# according to the columns we want to sort in, in that order
df[ do.call( order , df[ , match( sort_list , names(df) ) ] ) , ]
col1 col2 col3
10 3 5 1
9 3 2 2
7 3 2 3
8 5 1 3
6 1 5 4
3 3 4 4
2 4 3 4
5 5 1 4
1 2 5 5
4 5 3 5