Вы не можете сделать такое подмножество с $
. В исходном коде ( R/src/main/subset.c
) говорится:
/ * Оператор $ subset.
Нам нужно обязательно оценить только первый аргумент.
Второй будет символом, который нужно сопоставить, а не оценивать.
* /
Второй аргумент? Какой?! Вы должны понимать, что $
, как и все остальное в R (включая, например (
, +
и ^
т.д.), это функция, которая принимает аргументы и оценивается. df$V1
можно переписать как
`$`(df , V1)
или действительно
`$`(df , "V1")
Но...
`$`(df , paste0("V1") )
... например, никогда не будет работать, как и все остальное, что нужно сначала оценить во втором аргументе. Вы можете передавать только строку, которая никогда не оценивается.
Вместо этого используйте [
(или [[
если вы хотите извлечь только один столбец в качестве вектора).
Например,
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
для построения вызова order
. Вот воспроизводимый пример ниже:
# 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
Если я правильно понимаю, у вас есть вектор, содержащий имена переменных, и вы хотели бы перебрать каждое имя и отсортировать по ним фрейм данных. Если да, то этот пример должен проиллюстрировать вам решение. Основная проблема в вашем (полный пример не завершен, поэтому я не уверен, что еще вам может не хватать) заключается в том, что он должен быть
order(Q1_R1000[,parameter[X]])
вместоorder(Q1_R1000$parameter[X])
, поскольку параметр - это внешний объект, который содержит имя переменной, а не прямой столбец вашего фрейма данных (который$
будет уместным).источник
Использование dplyr обеспечивает простой синтаксис для сортировки фреймов данных
Было бы полезно использовать версию NSE, как показано здесь, чтобы разрешить динамическое построение списка сортировки.
источник
Другое решение - использовать #get:
источник
Была аналогичная проблема из-за некоторых файлов CSV, у которых были разные имена для одного и того же столбца.
Это было решение:
Я написал функцию для возврата первого допустимого имени столбца в списке, а затем использовал это ...
источник
если вы хотите выбрать столбец с определенным именем, просто сделайте
вы можете запустить его в цикле, а также в обратном порядке добавить динамическое имя, например, если A - это фрейм данных, а xyz - столбец, который будет назван как x, тогда мне это нравится
снова это также можно добавить в цикл
источник
источник
слишком поздно .. но я думаю, что у меня есть ответ -
Вот мой образец dataframe study.df -
А потом -
источник