Быстрый способ будет
cc <- function(...) sapply(substitute(...()), as.character)
cc(moses, abi, yoyoma)
# [1] "moses" "abi" "yoyoma"
Более гибкое решение может быть
cc <- function(..., simplify = TRUE, evaluate = FALSE) {
l <- eval(substitute(alist(...)))
ev <- if (evaluate) eval else identity
sapply(l, function(x) if (is.symbol(x)) as.character(x) else ev(x), simplify = simplify)
}
cc(moses, abi, yoyoma)
# [1] "moses" "abi" "yoyoma"
cc(one, two, 'three', four = 4)
# four
# "one" "two" "three" "4"
cc(one, two, 'three something' = rnorm(5), four = 4, simplify = FALSE)
# [[1]]
# [1] "one"
#
# [[2]]
# [1] "two"
#
# $`three something`
# rnorm(5)
#
# $four
# [1] 4
cc(one, two, 'three something' = rnorm(5), four = 4, simplify = FALSE, evaluate = TRUE)
# [[1]]
# [1] "one"
#
# [[2]]
# [1] "two"
#
# $`three something`
# [1] -1.1803114 0.3940908 -0.2296465 -0.2818132 1.3744525
#
# $four
# [1] 4
'куб.см <- функция (.. .) sapply (замените (...()), as.character); cc (moses, abi, yoyoma) ' – rawr
' First', это не список. Это вектор значений, когда вы используете 'c'. И, когда вы читаете их в R из файла, они читаются как вектор символов. Если они этого не делают, вы всегда можете использовать 'as.character' для их преобразования. – user5249203
Или 'as.character (замените (c (moses, abi, yoyoma))) [- 1]' –