在Rmarkdown文档中,我只想在尚未构建和保存的地块上构建地块,从而了解编织过程。
我使用下面的代码完成了这个操作,并给出了一个简单的示例。
x = rnorm(10)
if (! "figurename" %in% dir("figure")) {
png("figure/figurename.png")
hist(x)
dev.off()
} 现在,我想要创建一个函数,它自动执行上面的命令,并以一个绘图调用作为输入。此外,不应该评估情节调用(太慢了!)。我了解了substitute命令,并编写了以下内容:
x = rnorm(10)
plot_call = substitute(hist(x))
function(plot_call, figurename){
if (! figurename %in% dir("figure")) {
png(file.path("figure", figurename))
eval(plot_call)
dev.off()
}
knitr::include_graphics(file.path("figure", figurename))
}我对此有两个问题:
你认为如何?有更好的办法吗?
发布于 2020-05-13 09:30:46
缓存代码块的一种更正式的方法是利用块选项。在块头中添加一个简单的cache = TRUE将迫使每次代码块选项重新评估您的绘图,否则代码本身就会改变:
```{r expensive_plot, cache = TRUE}一些昂贵的地块
df %>%
ggplot(aes(x, y)) +geom_point()如果每次底层数据发生更改时都需要重新计算绘图,那么每次文件“最后编辑”字段发生更改时,都可以通过向选项中添加cache.extra = file.mtime('your-csv.csv')来使缓存失效。
https://stackoverflow.com/questions/61770529
复制相似问题