答案 0 :(得分:6)
原因是懒惰的评价。 (请不要让我解释详细信息。这很复杂,您可以使用language definition进行研究。但基本上,x
会在xlab
评估之前进行修改。)您可以使用force
:
gg <- function(x, xlab = deparse(substitute(x)), ylab = NA, freq = FALSE, ...) {
force(xlab)
x <- round(x)
ylab <- if(is.na(ylab) & freq) "Frequency" else if(is.na(ylab) & !freq) "Probability" else ylab
z <- if(freq) table(x) else table(x)/length(x)
plot(z, xlab = xlab, ylab = ylab, ...)
}
# Example of use:
gg(mtcars$gear)