knitr: run all chunks in an Rmarkdown document
You don't even have to use purl()
: if you knit
the document in the R console, the code is evaluated in the global environment (by default, see the envir=
option to knit()
).
So, if your file is my.Rmd
, then just run
library(knitr)
knit('my.Rmd')
A handy trick: if you want to only run up to a certain point in the document, insert an error like:
stop('here')
at the point in a code chunk you want it to stop, and set the following knitr
option:
opts_chunk$set(error=FALSE)
in the console before running knit()
.
Using Run all chunks
is equivalent to:
- Create a temporary R file
- Use
knitr::purl
to extract all the R chunks into the temp file - Use
source()
to run the file - Delete the temp file
Like this:
tempR <- tempfile(fileext = ".R")
library(knitr)
purl("SO-tag-package-dependencies.Rmd", output=tempR)
source(tempR)
unlink(tempR)
But you will want to turn this into a function. This is easy enough, except you have to use sys.source
to run the R script in the global environment:
runAllChunks <- function(rmd, envir=globalenv()){
tempR <- tempfile(tmpdir = ".", fileext = ".R")
on.exit(unlink(tempR))
knitr::purl(rmd, output=tempR)
sys.source(tempR, envir=envir)
}
runAllChunks("SO-tag-package-dependencies.Rmd")