这不识别包含的包
在您的示例中,first_package
并且second_package
都在第二个代码块的工作环境中可用。
尝试放入library(nycflights13)
R 文件和head(airlines)
Rmd 文件的第二块。如果包没有成功加载,调用knit("main.Rmd")
将失败。nycflights13
source
read_chunk
实际上确实做到了这一点(与 一起source
)但是他们以不同的方式去做。随着source
您将在source
(如您所见)之后直接使用全局功能。read_chunk
但是,正如您所指出的,因为它只评估代码,但不执行它,您需要显式执行该块,然后该函数将可用。(参见third_config_chunk
下面的示例。在报告中包含空块允许在后续块中调用third_config_chunk
全局。)some_function
关于“只评估代码,但不执行它”,这是 R 编程的一个完整属性,称为惰性评估。这个想法是您可能想要创建许多函数或模板代码,这些函数或模板代码会读入您的 R 环境但不会在现场执行,从而允许您在评估之前修改环境/参数。这也允许您多次执行相同的代码块,而source
只会使用已经提供的代码运行一次。
考虑一个示例,您有一个外部 R 脚本,其中包含报告中不需要的大量设置代码。可以将此文件格式化为许多“块”,这些“块”将被加载到工作环境中,read_chunk
但在明确告知之前不会被评估。
为了使您的config.R
使用外部化,您read_chunk()
可以将 R 脚本编写为:
配置文件
# ---- config_preamble
## setup code that is required for config.R
## to run but not for main.Rmd
# ---- first_config_chunk
library(nycflights13)
library(MASS)
# ---- second_config_chunk
y <- 1
# ---- third_config_chunk
some_function <- function(x) {
x + y
}
# ---- fourth_config_chunk
some_function(10)
# ---- config_output
## code that is output during `source`
## and not wanted in main.Rmd
print(some_function(10))
要将此脚本与外部化方法一起使用,您需要按如下方式设置main.Rmd :
主文件
```{r, include=FALSE}
knitr::read_chunk('config.R')
```
```{r first_config_chunk}
```
The packages are now loaded.
```{r third_config_chunk}
```
`some_function` is now available.
```{r new_chunk}
y <- 20
```
```{r fourth_config_chunk}
```
## [1] 30
```{r new_chunk_two}
y <- 100
lapply(seq(3), some_function)
```
## [[1]]
## [1] 101
##
## [[2]]
## [1] 102
##
## [[3]]
## [1] 103
```{r source_file_instead}
source("config.R")
```
## [1] 11
如您所见,如果您访问source
此文件,则无法some_function
在执行之前修改调用,并且调用将打印输出“11”。现在这些块在环境中可用,它们可以被重新调用任意次数(例如,在更改 的值之后y
)或在当前环境中以任何其他方式使用(例如),这在ifnew_chunk_two
中是不可能的source
您不希望 R 脚本的其余部分执行.