我认为有几种选择,我按我的喜好顺序显示。
## setup
require(ggplot2)
set.seed(10) # make reproducible
dat <- data.frame(x=1:10,y=runif(10))
我最喜欢的选择是为您的代码创建一个简单的函数包装器。然后,每当您需要更改数据时,只需将新数据传递给您的函数,它就会将其提供给ggplot
并创建新图形。这是灵活的并且对问题相当健壮。它也是可扩展的,因为如果以后您决定也希望能够更改标题,您也可以在函数中添加一个标题参数。
## my favorite option
myplot <- function(data) {
ggplot(data, aes(x, y)) + geom_point()
}
## use it
myplot(data = dat)
## change it
dat <- data.frame(x = 11:20, y = runif(10))
myplot(data = dat)
另一种方法是将调用保存ggplot
为未计算的表达式。然后,您只需在需要时对其进行评估。这几乎就像每次都输入代码(在某些方面有所不同,但这是我能想到的最好的类比)。
## not wild about this one
myplotcall <- expression(ggplot(dat, aes(x,y)) + geom_point())
## look at it (literally just the input)
myplotcall
expression(ggplot(dat, aes(x, y)) + geom_point())
## use it
eval(myplotcall)
## change it
dat <- data.frame(x = 21:30, y = runif(10))
eval(myplotcall)
您可以更改ggplot
对象本身的数据。我认为这种方法最容易出现问题,因为您正在处理并非真正打算由用户更改的对象的内部结构(即,仅仅因为我们可以并不意味着我们应该)。这更适合由%+%
操作员完成(参见 joran 的回答)
## not wild about this either
g <- ggplot(dat, aes(x,y)) + geom_point()
g ## use it
## change it
dat <- data.frame(x = 31:40, y = runif(10))
g$data <- dat
g