-- A --
all_labels()
all_rcpp_labels()
all_patterns
asis_output()
-- C --
cache_engines
clean_cache()
combine_words()
convert_chunk_header()
current_input()
-- D --
dep_auto()
dep_prev()
download_image()
-- E --
engine_output()
extract_raw_output()
-- F --
fig_chunk()
fig_path()
-- H --
hook_pdfcrop()
hook_optipng()
hook_pngquant()
hook_mogrify()
hook_plot_custom()
hook_purl()
hook_ffmpeg_html()
hook_gifski()
hook_scianimator()
hook_r2swf()
hook_movecode()
hook_plot_html()
hook_plot_asciidoc()
hook_plot_tex()
hook_plot_md()
hook_plot_rst()
hook_plot_textile()
hooks_html()
hooks_asciidoc()
hooks_latex()
hooks_sweave()
hooks_listings()
hooks_markdown()
hooks_jekyll()
hooks_rst()
hooks_textile()
-- I --
image_uri()
imgur_upload()
include_graphics()
include_url()
include_app()
inline_expr()
is_low_change()
is_latex_output()
is_html_output()
-- K --
knitr-package
knitr
kable()
kables()
knit()
knit2html()
knit2pandoc()
knit2pdf()
knit2wp()
knit_child()
knit_code
knit_engines
knit_exit()
knit_expand()
knit_filter()
knit_global()
knit_hooks
knit_meta()
knit_meta_add()
knit_params()
knit_params_yaml()
knit_patterns
knit_print()
knit_rd()
knit_rd_all()
knit_theme
knit_watch()
-- L --
load_cache()
-- N --
normal_print()
-- O --
opts_chunk
opts_current
opts_hooks
opts_knit
opts_template
-- P --
purl()
pandoc_to()
pandoc_from()
pandoc()
partition_chunk()
pat_rnw()
pat_brew()
pat_tex()
pat_html()
pat_md()
pat_rst()
pat_asciidoc()
pat_textile()
plot_crop()
-- R --
render_html()
render_asciidoc()
render_latex()
render_sweave()
render_listings()
render_markdown()
render_jekyll()
render_rst()
render_textile()
rand_seed
raw_block()
raw_latex()
raw_html()
restore_raw_output()
raw_output()
read_chunk()
read_demo()
rnw2pdf()
rocco()
rst2pdf()
-- S --
Sweave2knitr()
set_alias()
set_header()
set_parent()
sew()
spin()
spin_child()
stitch()
stitch_rhtml()
stitch_rmd()
-- V --
vignette_engines
-- W --
wrap_rmd()
write_bib()
The knitr package is an implementation of Literate Programming, a programming paradigm that intermingle code chunks (for computing) with prose (for documentation) in the same document.
When the document is compiled, the code chunks can be executed, and the results from computing (text or graphics) are automatically written to the output along with the prose.
This package is an alternative tool to Sweave with a more flexible design and new features like caching and finer control of graphics. It is not limited to LaTeX and is ready to be customized to process other file formats. See the package website in the references for more information and examples.
The pronunciation of knitr is similar to neater or you can
think of knitter (but it is single t). The name comes from
knit
+ R
(while Sweave
= S
+ weave
).
Yihui Xie <https://yihui.org>
Full documentation and demos: https://yihui.org/knitr/; FAQ's: https://yihui.org/knitr/faq/
The core function in this package: knit
. If you are an
Sweave user, see Sweave2knitr
on how to convert Sweave files
to knitr.
This function converts an Sweave document to a knitr-compatible document.
Sweave2knitr(
file,
output = gsub("[.]([^.]+)$", "-knitr.\\1", file),
text = NULL
)
file |
Path to the Rnw file (must be encoded in UTF-8). |
output |
Output file path. By default, ‘file.Rnw’ produces
‘file-knitr.Rnw’); if |
text |
An alternative way to provide the Sweave code as a character
string. If |
The pseudo command ‘\SweaveInput{file.Rnw}’ is converted to a code
chunk header <<child='file.Rnw'>>=
.
Similarly ‘\SweaveOpts{opt = value}’ is converted to a code chunk
‘opts_chunk$set(opt = value)’ with the chunk option include =
FALSE
; the options are automatically fixed in the same way as local chunk
options (explained below).
The Sweave package ‘\usepackage{Sweave}’ in the preamble is removed because it is not required.
Chunk options are updated if necessary: option values true
and
false
are changed to TRUE
and FALSE
respectively;
fig=TRUE
is removed because it is not necessary for knitr (plots
will be automatically generated); fig=FALSE
is changed to
fig.keep='none'
; the devices pdf/jpeg/png/eps/tikz=TRUE
are
converted to dev='pdf'/'jpeg'/'png'/'postscript'/'tikz'
;
pdf/jpeg/png/eps/tikz=FALSE
are removed;
results=tex/verbatim/hide
are changed to
results='asis'/'markup'/'hide'
; width/height
are changed to
fig.width/fig.height
; prefix.string
is changed to
fig.path
; print/term/prefix=TRUE/FALSE
are removed; most of the
character options (e.g. engine
and out.width
) are quoted;
keep.source=TRUE/FALSE
is changed to tidy=FALSE/TRUE
(note the
order of values).
If a line @
(it closes a chunk) directly follows a previous
@
, it is removed; if a line @
appears before a code chunk and
no chunk is before it, it is also removed, because knitr only uses one
‘@’ after ‘<<>>=’ by default (which is not the original Noweb
syntax but more natural).
If text
is NULL
, the output
file is written and
NULL
is returned. Otherwise, the converted text string is returned.
If ‘\SweaveOpts{}’ spans across multiple lines, it will not be
fixed, and you have to fix it manually. The LaTeX-style syntax of Sweave
chunks are ignored (see ?SweaveSyntaxLatex
); only the Noweb syntax
is supported.
The motivation of the changes in the syntax: https://yihui.org/knitr/demo/sweave/
Sweave2knitr(text = "<<echo=TRUE>>=") # this is valid
#> [1] "<<echo=TRUE>>="
Sweave2knitr(text = "<<png=true>>=") # dev='png'
#> [1] "<<dev='png'>>="
Sweave2knitr(text = "<<eps=TRUE, pdf=FALSE, results=tex, width=5, prefix.string=foo>>=")
#> [1] "<<dev='postscript', results='asis', fig.width=5, fig.path='foo'>>="
Sweave2knitr(text = "<<,png=false,fig=TRUE>>=")
#> [1] "<<>>="
Sweave2knitr(text = "\\SweaveOpts{echo=false}")
#> [1] "\n<<include=FALSE>>=\nlibrary(knitr)\nopts_chunk$set(\necho=FALSE\n)\n@\n"
Sweave2knitr(text = "\\SweaveInput{hello.Rnw}")
#> [1] "\n<<'child-hello.Rnw', child='hello.Rnw'>>=\n@\n"
# Sweave example in utils
testfile = system.file("Sweave", "Sweave-test-1.Rnw", package = "utils")
Sweave2knitr(testfile, output = "Sweave-test-knitr.Rnw")
if (interactive()) knit("Sweave-test-knitr.Rnw") # or knit2pdf() directly
unlink("Sweave-test-knitr.Rnw")
The function all_labels()
returns all chunk labels as a character
vector. Optionally, you can specify a series of conditions to filter the
labels. The function 'all_rcpp_labels()' is a wrapper function for
all_labels(engine == 'Rcpp')
.
all_labels(...)
all_rcpp_labels(...)
... |
A vector of R expressions, each of which should return |
For example, suppose the condition expression is engine == 'Rcpp'
, the
object engine
is the local chunk option engine
. If an
expression fails to be evaluated (e.g. when a certain object does not exist),
FALSE
is returned and the label for this chunk will be filtered out.
A character vector.
Empty code chunks are always ignored, including those chunks that are
empty in the original document but filled with code using chunk options
such as ref.label
or code
.
# the examples below are meaningless unless you put them in a knitr document
all_labels()
#> NULL
all_labels(engine == "Rcpp")
#> NULL
all_labels(echo == FALSE && results != "hide")
#> NULL
# or separate the two conditions
all_labels(echo == FALSE, results != "hide")
#> NULL
This object is a named list of all built-in patterns.
all_patterns
An object of class list
of length 8.
Usage: https://yihui.org/knitr/patterns/
all_patterns$rnw
#> $chunk.begin
#> [1] "^\\s*<<(.*)>>=.*$"
#>
#> $chunk.end
#> [1] "^\\s*@\\s*(%+.*|)$"
#>
#> $inline.code
#> [1] "\\\\Sexpr\\{([^}]+)\\}"
#>
#> $inline.comment
#> [1] "^\\s*%.*"
#>
#> $ref.chunk
#> [1] "^\\s*<<(.+)>>\\s*$"
#>
#> $header.begin
#> [1] "(^|\n)\\s*\\\\documentclass[^}]+\\}"
#>
#> $document.begin
#> [1] "\\s*\\\\begin\\{document\\}"
all_patterns$html
#> $chunk.begin
#> [1] "^\\s*<!--\\s*begin.rcode\\s*(.*)"
#>
#> $chunk.end
#> [1] "^\\s*end.rcode\\s*-->"
#>
#> $ref.chunk
#> [1] "^\\s*<<(.+)>>\\s*$"
#>
#> $inline.code
#> [1] "<!--\\s*rinline(.+?)-->"
#>
#> $header.begin
#> [1] "\\s*<head>"
str(all_patterns)
#> List of 8
#> $ rnw :List of 7
#> ..$ chunk.begin : chr "^\\s*<<(.*)>>=.*$"
#> ..$ chunk.end : chr "^\\s*@\\s*(%+.*|)$"
#> ..$ inline.code : chr "\\\\Sexpr\\{([^}]+)\\}"
#> ..$ inline.comment: chr "^\\s*%.*"
#> ..$ ref.chunk : chr "^\\s*<<(.+)>>\\s*$"
#> ..$ header.begin : chr "(^|\n)\\s*\\\\documentclass[^}]+\\}"
#> ..$ document.begin: chr "\\s*\\\\begin\\{document\\}"
#> $ brew :List of 1
#> ..$ inline.code: chr "<%[=]{0,1}\\s+([^%]+)\\s+[-]*%>"
#> $ tex :List of 8
#> ..$ chunk.begin : chr "^\\s*%+\\s*begin.rcode\\s*(.*)"
#> ..$ chunk.end : chr "^\\s*%+\\s*end.rcode"
#> ..$ chunk.code : chr "^\\s*%+"
#> ..$ ref.chunk : chr "^%+\\s*<<(.+)>>\\s*$"
#> ..$ inline.comment: chr "^\\s*%.*"
#> ..$ inline.code : chr "\\\\rinline\\{([^}]+)\\}"
#> ..$ header.begin : chr "(^|\n)\\s*\\\\documentclass[^}]+\\}"
#> ..$ document.begin: chr "\\s*\\\\begin\\{document\\}"
#> $ html :List of 5
#> ..$ chunk.begin : chr "^\\s*<!--\\s*begin.rcode\\s*(.*)"
#> ..$ chunk.end : chr "^\\s*end.rcode\\s*-->"
#> ..$ ref.chunk : chr "^\\s*<<(.+)>>\\s*$"
#> ..$ inline.code : chr "<!--\\s*rinline(.+?)-->"
#> ..$ header.begin: chr "\\s*<head>"
#> $ md :List of 4
#> ..$ chunk.begin: chr "^[\t >]*```+\\s*\\{([a-zA-Z0-9_]+( *[ ,].*)?)\\}\\s*$"
#> ..$ chunk.end : chr "^[\t >]*```+\\s*$"
#> ..$ ref.chunk : chr "^\\s*<<(.+)>>\\s*$"
#> ..$ inline.code: chr "(?<!(^``))(?<!(\n``))`r[ #]([^`]+)\\s*`"
#> $ rst :List of 5
#> ..$ chunk.begin: chr "^\\s*[.][.]\\s+\\{r(.*)\\}\\s*$"
#> ..$ chunk.end : chr "^\\s*[.][.]\\s+[.][.]\\s*$"
#> ..$ chunk.code : chr "^\\s*[.][.]"
#> ..$ ref.chunk : chr "^\\.*\\s*<<(.+)>>\\s*$"
#> ..$ inline.code: chr ":r:`([^`]+)`"
#> $ asciidoc:List of 6
#> ..$ chunk.begin : chr "^//\\s*begin[.]rcode(.*)$"
#> ..$ chunk.end : chr "^//\\s*end[.]rcode\\s*$"
#> ..$ chunk.code : chr "^//+"
#> ..$ ref.chunk : chr "^\\s*<<(.+)>>\\s*$"
#> ..$ inline.code : chr "`r +([^`]+)\\s*`|[+]r +([^+]+)\\s*[+]"
#> ..$ inline.comment: chr "^//.*"
#> $ textile :List of 5
#> ..$ chunk.begin : chr "^###[.]\\s+begin[.]rcode(.*)$"
#> ..$ chunk.end : chr "^###[.]\\s+end[.]rcode\\s*$"
#> ..$ ref.chunk : chr "^\\s*<<(.+)>>\\s*$"
#> ..$ inline.code : chr "@r +([^@]+)\\s*@"
#> ..$ inline.comment: chr "^###[.].*"
This is a convenience function that assigns the input object a class named
knit_asis
, so that knitr will treat it as is (the effect is the
same as the chunk option results = 'asis'
) when it is written to the
output.
asis_output(x, meta = NULL, cacheable = NA)
x |
An R object. Typically a character string, or an object which can
be converted to a character string via |
meta |
Additional metadata of the object to be printed. The metadata
will be collected when the object is printed, and accessible via
|
cacheable |
Boolean indicating whether this object is cacheable. If
|
This function is normally used in a custom S3 method based on the printing
function knit_print()
.
For the cacheable
argument, you need to be careful when printing the
object involves non-trivial side effects, in which case it is strongly
recommended to use cacheable = FALSE
to instruct knitr that this
object should not be cached using the chunk option cache = TRUE
,
otherwise the side effects will be lost the next time the chunk is knitted.
For example, printing a shiny input element or an HTML widget in an R
Markdown document may involve registering metadata about some JavaScript
libraries or stylesheets, and the metadata may be lost if we cache the code
chunk, because the code evaluation will be skipped the next time. This
particular issue has been solved in knitr after v1.13 (the metadata
will be saved and loaded automatically when caching is enabled), but not all
metadata can be saved and loaded next time and still works in the new R
session.
This function only works in top-level R expressions, and it will not work when it is called inside another expression, such as a for-loop. See https://github.com/yihui/knitr/issues/1137 for a discussion.
# see ?knit_print
This object controls how to load cached environments from languages other
than R (when the chunk option engine
is not 'R'
). Each
component in this object is a function that takes the current path to the
chunk cache and loads it into the language environment.
cache_engines
An object of class list
of length 7.
The cache engine function has one argument options
, a list containing
all chunk options. Note that options$hash
is the path to the current
chunk cache with the chunk's hash, but without any file extension, and the
language engine may write a cache database to this path (with an extension).
The cache engine function should load the cache environment and should know the extension appropriate for the language.
See https://github.com/rstudio/reticulate/pull/167 for an implementation of a cache engine for Python.
Hook functions are called when the corresponding chunk options are not
NULL
to do additional jobs beside the R code in chunks. This package
provides a few useful hooks, which can also serve as examples of how to
define chunk hooks in knitr.
hook_pdfcrop(before, ...)
hook_optipng(...)
hook_pngquant(...)
hook_mogrify(...)
hook_plot_custom(before, options, envir)
hook_purl(before, options, ...)
before , options , envir , ... |
See References below. |
The function hook_pdfcrop()
calls plot_crop()
to crop
the white margins of PDF plots.
The function hook_optipng()
calls the program optipng
to
optimize PNG images. Note the chunk option optipng
can be used to
provide additional parameters to the program optipng
, e.g.
optipng = '-o7'
.
The function hook_pngquant()
calls the program pngquant
to
optimize PNG images. Note the chunk option pngquant
can be used to
provide additional parameters to the program pngquant
, e.g.
pngquant = '--speed=1 --quality=0-50'
.
The function hook_mogrify()
calls the program mogrify
. Note
the chunk option mogrify
can be used to provide additional parameters
to the program mogrify
(with default -trim
to trim PNG
files).
When the plots are not recordable via grDevices::recordPlot()
and we save the plots to files manually via other functions (e.g. rgl
plots), we can use the chunk hook hook_plot_custom
to help write code
for graphics output into the output document.
The hook hook_purl()
can be used to write the code chunks to an R
script. It is an alternative approach to purl
, and can be more
reliable when the code chunks depend on the execution of them (e.g.
read_chunk()
, or opts_chunk$set(eval = FALSE)
).
To enable this hook, it is recommended to associate it with the chunk option
purl
, i.e. knit_hooks$set(purl = hook_purl)
. When this hook is
enabled, an R script will be written while the input document is being
knit
. Currently the code chunks that are not R code or have the
chunk option purl=FALSE
are ignored. Please note when the cache is
turned on (the chunk option cache = TRUE
), no chunk hooks will be
executed, hence hook_purl()
will not work, either. To solve this
problem, we need cache = 2
instead of TRUE
(see
https://yihui.org/knitr/demo/cache/ for the meaning of cache =
2
).
The two hook functions hook_rgl()
and hook_webgl()
were
moved from knitr to the rgl package (>= v0.95.1247) after
knitr v1.10.5, and you can library(rgl)
to get them.
https://yihui.org/knitr/hooks/#chunk-hooks
rgl::rgl.snapshot
,
rgl::rgl.postscript
,
rgl::hook_rgl
,
rgl::hook_webgl
if (require("rgl") && exists("hook_rgl")) knit_hooks$set(rgl = hook_rgl)
#> RGL: unable to open X11 display
#> 'rgl.init' failed, will use the null device.
#> See '?rgl.useNULL' for ways to avoid this warning.
# then in code chunks, use the option rgl=TRUE
If you remove or rename some cached code chunks, their original cache files will not be automatically cleaned. You can use this function to identify these possible files, and clean them if you are sure they are no longer needed.
clean_cache(clean = FALSE, path = opts_chunk$get("cache.path"))
clean |
Boolean; whether to remove the files. |
path |
Path to the cache. |
The identification is not guaranteed to be correct, especially when
multiple documents share the same cache directory. You are recommended to
call clean_cache(FALSE)
and carefully check the list of files (if
any) before you really delete them (clean_cache(TRUE)
).
This function must be called within a code chunk in a source document, since it needs to know all chunk labels of the current document to determine which labels are no longer present, and delete cache corresponding to these labels.
This is a wrapper function of xfun::join_words()
.
combine_words(...)
... |
Arguments passed to |
This is a helper function for moving chunk options from the chunk header to the chunk body using the new syntax.
convert_chunk_header(
input,
output = NULL,
type = c("multiline", "wrap", "yaml"),
width = 0.9 * getOption("width")
)
input |
File path to the document with code chunks to convert. |
output |
The default |
type |
This determines how the in-body options will be formatted.
|
width |
An integer passed to |
A character vector of converted input
when output =
NULL
. The output file path with converted content otherwise.
Historical chunk option syntax have chunk option in the chunk header using
valid R syntax. This is an example for .Rmd
document
```{r, echo = FALSE, fig.width: 10} ```
New syntax allows to pass option inside the chunk using several variants
Passing options one per line using valid R syntax. This corresponds to convert_chunk_header(type = "multiline")
.
```{r} #| echo = FALSE, #| fig.width = 10 ```
Passing option part from header in-chunk with several line if wrapping is
needed. This corresponds to convert_chunk_header(type = "wrap")
```{r} #| echo = FALSE, fig.width = 10 ```
Passing options key value pairs in-chunk using YAML syntax. Values are no
more R expression but valid YAML syntax. This corresponds to
convert_chunk_header(type = "yaml")
(not implement yet).
```{r} #| echo: false, #| fig.width: 10 ```
Learn more about the new chunk option syntax in https://yihui.org/en/2022/01/knitr-news/
knitr_example = function(...) system.file("examples", ..., package = "knitr")
# Convert a document for multiline type
convert_chunk_header(knitr_example("knitr-minimal.Rmd"))
#> [1] "# A Minimal Example for Markdown"
#> [2] ""
#> [3] "This is a minimal example of using **knitr** to produce an _HTML_ page from _Markdown_."
#> [4] ""
#> [5] "## R code chunks"
#> [6] ""
#> [7] "```{r}"
#> [8] "#| label = \"setup\""
#> [9] "# set global chunk options: images will be 7x5 inches"
#> [10] "knitr::opts_chunk$set(fig.width=7, fig.height=5)"
#> [11] "options(digits = 4)"
#> [12] "```"
#> [13] ""
#> [14] "Now we write some code chunks in this markdown file:"
#> [15] ""
#> [16] "```{r}"
#> [17] "#| label = \"computing\""
#> [18] "x <- 1+1 # a simple calculator"
#> [19] "set.seed(123)"
#> [20] "rnorm(5) # boring random numbers"
#> [21] "```"
#> [22] ""
#> [23] "We can also produce plots:"
#> [24] ""
#> [25] "```{r}"
#> [26] "#| label = \"graphics\""
#> [27] "par(mar = c(4, 4, .1, .1))"
#> [28] "with(mtcars, {"
#> [29] " plot(mpg~hp, pch=20, col='darkgray')"
#> [30] " lines(lowess(hp, mpg))"
#> [31] "})"
#> [32] "```"
#> [33] ""
#> [34] "## Inline code"
#> [35] ""
#> [36] "Inline R code is also supported, e.g. the value of `x` is `r x`, and 2 × π"
#> [37] "= `r 2*pi`."
#> [38] ""
#> [39] "## Math"
#> [40] ""
#> [41] "LaTeX math as usual: $f(\\alpha, \\beta) \\propto x^{\\alpha-1}(1-x)^{\\beta-1}$."
#> [42] ""
#> [43] "## Misc"
#> [44] ""
#> [45] "You can indent code chunks so they can nest within other environments such as lists."
#> [46] ""
#> [47] "1. the area of a circle with radius x"
#> [48] " ```{r}"
#> [49] " #| label = \"foo\""
#> [50] " pi * x^2"
#> [51] " ```"
#> [52] "2. OK, that is great"
#> [53] ""
#> [54] "To compile me, use"
#> [55] ""
#> [56] "```{r}"
#> [57] "#| label = \"compile\","
#> [58] "#| eval = FALSE"
#> [59] "library(knitr)"
#> [60] "knit('knitr-minimal.Rmd')"
#> [61] "```"
#> [62] ""
#> [63] "## Conclusion"
#> [64] ""
#> [65] "Markdown is super easy to write. Go to **knitr** [homepage](https://yihui.org/knitr/) for details."
# Convert a document for wrap type
convert_chunk_header(knitr_example("knitr-minimal.Rmd"), type = "wrap")
#> [1] "# A Minimal Example for Markdown"
#> [2] ""
#> [3] "This is a minimal example of using **knitr** to produce an _HTML_ page from _Markdown_."
#> [4] ""
#> [5] "## R code chunks"
#> [6] ""
#> [7] "```{r}"
#> [8] "#| setup"
#> [9] "# set global chunk options: images will be 7x5 inches"
#> [10] "knitr::opts_chunk$set(fig.width=7, fig.height=5)"
#> [11] "options(digits = 4)"
#> [12] "```"
#> [13] ""
#> [14] "Now we write some code chunks in this markdown file:"
#> [15] ""
#> [16] "```{r}"
#> [17] "#| computing"
#> [18] "x <- 1+1 # a simple calculator"
#> [19] "set.seed(123)"
#> [20] "rnorm(5) # boring random numbers"
#> [21] "```"
#> [22] ""
#> [23] "We can also produce plots:"
#> [24] ""
#> [25] "```{r}"
#> [26] "#| graphics"
#> [27] "par(mar = c(4, 4, .1, .1))"
#> [28] "with(mtcars, {"
#> [29] " plot(mpg~hp, pch=20, col='darkgray')"
#> [30] " lines(lowess(hp, mpg))"
#> [31] "})"
#> [32] "```"
#> [33] ""
#> [34] "## Inline code"
#> [35] ""
#> [36] "Inline R code is also supported, e.g. the value of `x` is `r x`, and 2 × π"
#> [37] "= `r 2*pi`."
#> [38] ""
#> [39] "## Math"
#> [40] ""
#> [41] "LaTeX math as usual: $f(\\alpha, \\beta) \\propto x^{\\alpha-1}(1-x)^{\\beta-1}$."
#> [42] ""
#> [43] "## Misc"
#> [44] ""
#> [45] "You can indent code chunks so they can nest within other environments such as lists."
#> [46] ""
#> [47] "1. the area of a circle with radius x"
#> [48] " ```{r}"
#> [49] " #| foo"
#> [50] " pi * x^2"
#> [51] " ```"
#> [52] "2. OK, that is great"
#> [53] ""
#> [54] "To compile me, use"
#> [55] ""
#> [56] "```{r}"
#> [57] "#| compile, eval=FALSE"
#> [58] "library(knitr)"
#> [59] "knit('knitr-minimal.Rmd')"
#> [60] "```"
#> [61] ""
#> [62] "## Conclusion"
#> [63] ""
#> [64] "Markdown is super easy to write. Go to **knitr** [homepage](https://yihui.org/knitr/) for details."
# Reduce default wrapping width
convert_chunk_header(knitr_example("knitr-minimal.Rmd"), type = "wrap", width = 0.6 *
getOption("width"))
#> [1] "# A Minimal Example for Markdown"
#> [2] ""
#> [3] "This is a minimal example of using **knitr** to produce an _HTML_ page from _Markdown_."
#> [4] ""
#> [5] "## R code chunks"
#> [6] ""
#> [7] "```{r}"
#> [8] "#| setup"
#> [9] "# set global chunk options: images will be 7x5 inches"
#> [10] "knitr::opts_chunk$set(fig.width=7, fig.height=5)"
#> [11] "options(digits = 4)"
#> [12] "```"
#> [13] ""
#> [14] "Now we write some code chunks in this markdown file:"
#> [15] ""
#> [16] "```{r}"
#> [17] "#| computing"
#> [18] "x <- 1+1 # a simple calculator"
#> [19] "set.seed(123)"
#> [20] "rnorm(5) # boring random numbers"
#> [21] "```"
#> [22] ""
#> [23] "We can also produce plots:"
#> [24] ""
#> [25] "```{r}"
#> [26] "#| graphics"
#> [27] "par(mar = c(4, 4, .1, .1))"
#> [28] "with(mtcars, {"
#> [29] " plot(mpg~hp, pch=20, col='darkgray')"
#> [30] " lines(lowess(hp, mpg))"
#> [31] "})"
#> [32] "```"
#> [33] ""
#> [34] "## Inline code"
#> [35] ""
#> [36] "Inline R code is also supported, e.g. the value of `x` is `r x`, and 2 × π"
#> [37] "= `r 2*pi`."
#> [38] ""
#> [39] "## Math"
#> [40] ""
#> [41] "LaTeX math as usual: $f(\\alpha, \\beta) \\propto x^{\\alpha-1}(1-x)^{\\beta-1}$."
#> [42] ""
#> [43] "## Misc"
#> [44] ""
#> [45] "You can indent code chunks so they can nest within other environments such as lists."
#> [46] ""
#> [47] "1. the area of a circle with radius x"
#> [48] " ```{r}"
#> [49] " #| foo"
#> [50] " pi * x^2"
#> [51] " ```"
#> [52] "2. OK, that is great"
#> [53] ""
#> [54] "To compile me, use"
#> [55] ""
#> [56] "```{r}"
#> [57] "#| compile, eval=FALSE"
#> [58] "library(knitr)"
#> [59] "knit('knitr-minimal.Rmd')"
#> [60] "```"
#> [61] ""
#> [62] "## Conclusion"
#> [63] ""
#> [64] "Markdown is super easy to write. Go to **knitr** [homepage](https://yihui.org/knitr/) for details."
# Explicitly name the output
convert_chunk_header("test.Rmd", output = "test2.Rmd")
# Overwrite the input
convert_chunk_header("test.Rmd", output = identity)
# Use a custom function to name the output
convert_chunk_header("test.Rmd", output = \(f) sprintf("%s-new.%s",
xfun::sans_ext(f), xfun::file_ext(f)))
Returns the name of the input file passed to knit()
.
current_input(dir = FALSE)
dir |
Boolean; whether to prepend the current working directory to the file path, i.e. whether to return an absolute path or a relative path. |
A character string, if this function is called inside an input
document. Otherwise NULL
.
When the chunk option autodep = TRUE
, all names of objects created in
a chunk will be saved in a file named ‘__objects’ and all global objects
used in a chunk will be saved to ‘__globals’. This function can analyze
object names in these files to automatically build cache dependencies, which
is similar to the effect of the dependson
option. It is supposed to be
used in the first chunk of a document and this chunk must not be cached.
dep_auto(path = opts_chunk$get("cache.path"), labels = all_labels())
path |
Path to the dependency file. |
labels |
A vector of labels of chunks for which the dependencies will be built. By default, dependencies for all chunks will be built. |
NULL
. The dependencies are built as a side effect.
Be cautious about path
: because this function is used in a
chunk, the working directory when the chunk is evaluated is the directory
of the input document in knit
, and if that directory differs
from the working directory before calling knit()
, you need to adjust
the path
argument here to make sure this function can find the cache
files ‘__objects’ and ‘__globals’.
https://yihui.org/knitr/demo/cache/
This function can be used to build dependencies among chunks so that all later chunks depend on previous chunks, i.e. whenever the cache of a previous chunk is updated, the cache of all its later chunks will be updated.
dep_prev()
NULL
; the internal dependency structure is updated as a side
effect.
https://yihui.org/knitr/demo/cache/
When including images in non-HTML output formats such as LaTeX/PDF, URLs will
not work as image paths. In this case, we have to download the images. This
function is a wrapper of xfun::download_file()
and
include_graphics()
.
download_image(
url,
path = xfun::url_filename(url),
use_file = !pandoc_to("html"),
...
)
url |
The URL of an image. |
path |
The download path (inferred from the URL by default). If the file exists, it will not be downloaded (downloading can take time and requires Internet connection). If you are sure the file needs to be downloaded again, delete it beforehand. |
use_file |
Whether to use the URL or the download path to include the image. By default, the URL is used for HTML output formats, and the file path is used for other output formats. |
... |
Other arguments to be passed to |
knitr::download_image("https://www.r-project.org/Rlogo.png")
#> [1] "Rlogo.png"
#> attr(,"class")
#> [1] "knit_image_paths" "knit_asis"
If you have designed a language engine, you may call this function in the end to format and return the text output from your engine.
engine_output(options, code, out, extra = NULL)
options |
A list of chunk options. Usually this is just the object
|
code |
Source code of the chunk, to which the output hook |
out |
Text output from the engine, to which the hook |
extra |
Any additional text output that you want to include. |
For expert users, an advanced usage of this function is
engine_output(options, out = LIST)
where LIST
is a list that
has the same structure as the output of evaluate::evaluate()
. In this
case, the arguments code
and extra
are ignored, and the list is
passed to knitr::sew()
to return a character vector of final output.
A character string generated from the source code and output using the appropriate output hooks.
library(knitr)
engine_output(opts_chunk$merge(list(engine = "Rscript")),
code = "1 + 1", out = "[1] 2")
#> [1] "1 + 1\n## [1] 2\n"
engine_output(opts_chunk$merge(list(echo = FALSE, engine = "Rscript")),
code = "1 + 1", out = "[1] 2")
#> [1] "## [1] 2\n"
# expert use only
engine_output(opts_chunk$merge(list(engine = "python")),
out = list(structure(list(src = "1 + 1"), class = "source"),
"2"))
#> [1] "1 + 1" "## 2\n"
Given a chunk label, the figure file extension, the figure number(s), and the
chunk option fig.path
, return the filename(s).
fig_chunk(label, ext = "", number, fig.path = opts_chunk$get("fig.path"))
label |
The chunk label. |
ext |
The figure file extension, e.g. |
number |
The figure number (by default |
fig.path |
Passed to |
This function can be used in an inline R expression to write out the figure
filenames without hard-coding them. For example, if you created a plot in a
code chunk with the label foo
and figure path ‘my-figure/’, you
are not recommended to use hard-coded figure paths like
‘\includegraphics{my-figure/foo-1.pdf}’ (in ‘.Rnw’ documents) or
‘![](my-figure/foo-1.png)’ (R Markdown) in your document. Instead, you
should use ‘\Sexpr{fig_chunk('foo', 'pdf')}’ or ‘![](`r
fig_chunk('foo', 'png')`)’.
You can generate plots in a code chunk but not show them inside the code
chunk by using the chunk option fig.show = 'hide'
. Then you can use
this function if you want to show them elsewhere.
A character vector of filenames.
library(knitr)
fig_chunk("foo", "png")
#> [1] "figure/foo-1.png"
fig_chunk("foo", "pdf")
#> [1] "figure/foo-1.pdf"
fig_chunk("foo", "svg", 2) # the second plot of the chunk foo
#> [1] "figure/foo-2.svg"
fig_chunk("foo", "png", 1:5) # if the chunk foo produced 5 plots
#> [1] "figure/foo-1.png" "figure/foo-2.png" "figure/foo-3.png" "figure/foo-4.png"
#> [5] "figure/foo-5.png"
The filename of figure files is the combination of options fig.path
and label
. This function returns the path of figures for the current
chunk by default.
fig_path(suffix = "", options = opts_current$get(), number)
suffix |
A filename suffix; if it is non-empty and does not
contain a dot |
options |
A list of options; by default the options of the current chunk. |
number |
The current figure number. The default is the internal chunk option
|
A character vector of the form ‘fig.path-label-i.suffix’.
When there are special characters (not alphanumeric or ‘-’ or ‘_’) in the path, they will be automatically replaced with ‘_’. For example, ‘a b/c.d-’ will be sanitized to ‘a_b/c_d-’. This makes the filenames safe to LaTeX.
fig_path(".pdf", options = list(fig.path = "figure/abc-", label = "first-plot"))
#> [1] "figure/abc-first-plot-1.pdf"
fig_path(".png", list(fig.path = "foo-", label = "bar"), 1:10)
#> [1] "foo-bar-1.png" "foo-bar-2.png" "foo-bar-3.png" "foo-bar-4.png"
#> [5] "foo-bar-5.png" "foo-bar-6.png" "foo-bar-7.png" "foo-bar-8.png"
#> [9] "foo-bar-9.png" "foo-bar-10.png"
hook_ffmpeg_html()
uses FFmpeg to convert images to a video;
hook_gifski()
uses the gifski to convert images to a GIF
animation; hook_scianimator()
uses the JavaScript library SciAnimator
to create animations; hook_r2swf()
uses the R2SWF package.
hook_ffmpeg_html(x, options)
hook_gifski(x, options)
hook_scianimator(x, options)
hook_r2swf(x, options)
x |
Filename for the plot (a character string). |
options |
A list of the current chunk options. |
These hooks are mainly for the package option animation.fun
, e.g. you
can set opts_knit$set(animation.fun = hook_scianimator)
.
A document hook is a function to post-process the output document.
hook_movecode(x)
x |
A character string (the whole output document). |
hook_movecode()
is a document hook to move code chunks out of LaTeX
floating environments like ‘figure’ and ‘table’ when the chunks
were actually written inside the floats. This function is primarily designed
for LyX: we often insert code chunks into floats to generate figures or
tables, but in the final output we do not want the code to float with the
environments, so we use regular expressions to find out the floating
environments, extract the code chunks and move them out. To disable this
behavior, use a comment % knitr_do_not_move
in the floating
environment.
The post-processed document as a character string.
These functions are hackish. Also note hook_movecode()
assumes
you to use the default output hooks for LaTeX (not Sweave or listings), and
every figure/table environment must have a label.
https://yihui.org/knitr/hooks/
knit_hooks$set(document = hook_movecode)
# see example 103 at https://github.com/yihui/knitr-examples
These hook functions define how to mark up graphics output in different output formats.
hook_plot_html(x, options)
hook_plot_asciidoc(x, options)
hook_plot_tex(x, options)
hook_plot_md(x, options)
hook_plot_rst(x, options)
hook_plot_textile(x, options)
x |
Filename for the plot (a character string). |
options |
A list of the current chunk options. |
Depending on the options passed over, hook_plot_tex
may return the
normal ‘\includegraphics{}’ command, or ‘\input{}’ (for tikz
files), or ‘\animategraphics{}’ (for animations); it also takes many
other options into consideration to align plots and set figure sizes, etc.
Similarly, hook_plot_html
, hook_plot_md
and
hook_plot_rst
return character strings which are HTML, Markdown, reST
code.
In most cases we do not need to call these hooks explicitly, and they were
designed to be used internally. Sometimes we may not be able to record R
plots using grDevices::recordPlot()
, and we can make use of
these hooks to insert graphics output in the output document; see
hook_plot_custom
for details.
A character string of code, with plot filenames wrapped.
https://yihui.org/knitr/hooks/
# this is what happens for a chunk like this
# <<foo-bar-plot, dev='pdf', fig.align='right'>>=
hook_plot_tex("foo-bar-plot.pdf", opts_chunk$merge(list(fig.align = "right")))
#> [1] "\n\n\\hfill{}\\includegraphics{foo-bar-plot} \n\n"
# <<bar, dev='tikz'>>=
hook_plot_tex("bar.tikz", opts_chunk$merge(list(dev = "tikz")))
#> [1] "\n\\includegraphics{bar} "
# <<foo, dev='pdf', fig.show='animate', interval=.1>>=
# 5 plots are generated in this chunk
hook_plot_tex("foo5.pdf", opts_chunk$merge(list(fig.show = "animate", interval = 0.1,
fig.cur = 5, fig.num = 5)))
#> [1] "\n\\animategraphics[,controls,loop]{10}{foo}{1}{5}"
This function is the same as xfun::base64_uri()
(only with a
different function name). It can encode an image file as a base64 string,
which can be used in the img
tag in HTML.
image_uri(f)
f |
Path to the image file. |
The data URI as a character string.
Wush Wu and Yihui Xie
https://en.wikipedia.org/wiki/Data_URI_scheme
uri = image_uri(file.path(R.home("doc"), "html", "logo.jpg"))
if (interactive()) {
cat(sprintf("<img src=\"%s\" />", uri), file = "logo.html")
browseURL("logo.html") # you can check its HTML source
}
This function is an alias to xfun::upload_imgur()
. It is kept in
knitr only for backward-compatibility reasons. You are recommended to
use xfun::upload_imgur()
directly instead.
imgur_upload(file, key = xfun::env_option("knitr.imgur.key"), ...)
file , key , ... |
See |
When plots are not generated from R code, there is no way for knitr to
capture plots automatically. In this case, you may generate the images
manually and pass their file paths to this function to include them in the
output. The major advantage of using this function is that it is portable in
the sense that it works for all document formats that knitr supports,
so you do not need to think if you have to use, for example, LaTeX or
Markdown syntax, to embed an external image. Chunk options related to
graphics output that work for normal R plots also work for these images, such
as out.width
and out.height
.
include_graphics(
path,
auto_pdf = getOption("knitr.graphics.auto_pdf", FALSE),
dpi = NULL,
rel_path = getOption("knitr.graphics.rel_path", TRUE),
error = getOption("knitr.graphics.error", TRUE)
)
path |
A character vector of image paths. Both local file paths and web
paths are supported. Note that the |
auto_pdf |
Whether to use PDF images automatically when the output
format is LaTeX. If |
dpi |
DPI (dots per inch) value. Used to calculate the output width (in
inches) of the images. This will be their actual width in pixels, divided
by |
rel_path |
Whether to automatically convert absolute paths to relative
paths. If you know for sure that absolute paths work, you may set this
argument or the global option |
error |
Whether to signal an error if any files specified in the
|
The same as the input character vector path
but it is marked
with special internal S3 classes so that knitr will convert the file
paths to proper output code according to the output format.
This function is supposed to be used in R code chunks or inline R code expressions. For local images, you are recommended to use relative paths with forward slashes instead of backslashes (e.g., ‘images/fig1.png’ instead of ‘/Users/me/code/images/fig1.png’).
The automatic calculation of the output width requires the png
package (for PNG images) or the jpeg package (for JPEG images). The
width will not be calculated if the chunk option out.width
is
already provided or dpi = NA
.
When the output format is HTML, include_url()
inserts an iframe in the
output; otherwise it takes a screenshot of the URL and insert the image in
the output. include_app()
takes the URL of a Shiny app and adds
‘?showcase=0’ to it (to disable the showcase mode), then passes the URL
to include_url()
.
include_url(url, height = "400px")
include_app(url, height = "400px")
url |
A character vector of URLs. |
height |
A character vector to specify the height of iframes. |
An R object with a special class that knitr recognizes internally to generate the iframes or screenshots.
This is a convenience function to write the "source code" of inline R expressions. For example, if you want to write ‘`r 1+1`’ literally in an R Markdown document, you may write ‘`` `r knitr::inline_expr('1+1')` ``’; for Rnw documents, this may be ‘\verb|\Sexpr{knitr::inline_expr{'1+1'}}|’.
inline_expr(code, syntax)
code |
Character string of the inline R source code. |
syntax |
A character string to specify the syntax, e.g. |
A character string marked up using the inline R code syntax.
library(knitr)
inline_expr("1+1", "rnw")
#> [1] "\\Sexpr{1+1}"
inline_expr("1+1", "html")
#> [1] "<!--rinline 1+1 -->"
inline_expr("1+1", "md")
#> [1] "`r 1+1`"
Check if one plot only contains a low-level update of another plot.
is_low_change(p1, p2)
p1 , p2 |
Plot objects. |
Logical value indicating whether p2
is a low-level update of
p1
.
pdf(NULL)
dev.control("enable") # enable plot recording
plot(1:10)
p1 = recordPlot()
abline(0, 1) # add a line (a low-level change)
p2 = recordPlot()
plot(rnorm(100))
p3 = recordPlot() # draw a completely new plot
dev.off()
#> png
#> 2
knitr::is_low_change(p1, p2) # true
#> [1] TRUE
knitr::is_low_change(p1, p3) # false
#> [1] FALSE
A very simple table generator, and it is simple by design. It is not intended
to replace any other R packages for making tables. The kable()
function returns a single table for a single data object, and returns a table
that contains multiple tables if the input object is a list of data objects.
The kables()
function is similar to kable(x)
when x
is a
list of data objects, but kables()
accepts a list of kable()
values directly instead of data objects (see examples below).
kable(
x,
format,
digits = getOption("digits"),
row.names = NA,
col.names = NA,
align,
caption = opts_current$get("tab.cap"),
label = NULL,
format.args = list(),
escape = TRUE,
...
)
kables(x, format, caption = NULL, label = NULL)
x |
For |
format |
A character string. Possible values are |
digits |
Maximum number of digits for numeric columns, passed to
|
row.names |
Logical: whether to include row names. By default, row names
are included if |
col.names |
A character vector of column names to be used in the table. |
align |
Column alignment: a character vector consisting of |
caption |
The table caption. By default, it is retrieved from the chunk
option |
label |
The table reference label. By default, the label is obtained
from |
format.args |
A list of arguments to be passed to |
escape |
Boolean; whether to escape special characters when producing
HTML or LaTeX tables. When |
... |
Other arguments (see Examples and References). |
Missing values (NA
) in the table are displayed as NA
by
default. If you want to display them with other characters, you can set the
option knitr.kable.NA
, e.g. options(knitr.kable.NA = '')
to
hide NA
values.
You can set the option knitr.kable.max_rows
to limit the number of
rows to show in the table, e.g., options(knitr.kable.max_rows = 30)
.
A character vector of the table source code.
When using kable()
as a top-level expression, you do not
need to explicitly print()
it due to R's automatic implicit
printing. When it is wrapped inside other expressions (such as a
for
loop), you must explicitly print(kable(...))
.
See
https://bookdown.org/yihui/rmarkdown-cookbook/kable.html for some
examples about this function, including specific arguments according to the
format
selected.
Other R packages such as huxtable, xtable, kableExtra, gt and tables for HTML and LaTeX tables, and ascii and pander for different flavors of markdown output and some advanced features and table styles. For more on other packages for creating tables, see https://bookdown.org/yihui/rmarkdown-cookbook/table-other.html.
d1 = head(iris)
d2 = head(mtcars)
# pipe tables by default
kable(d1)
#> | Sepal.Length| Sepal.Width| Petal.Length| Petal.Width|Species |
#> |------------:|-----------:|------------:|-----------:|:-------|
#> | 5.1| 3.5| 1.4| 0.2|setosa |
#> | 4.9| 3.0| 1.4| 0.2|setosa |
#> | 4.7| 3.2| 1.3| 0.2|setosa |
#> | 4.6| 3.1| 1.5| 0.2|setosa |
#> | 5.0| 3.6| 1.4| 0.2|setosa |
#> | 5.4| 3.9| 1.7| 0.4|setosa |
kable(d2[, 1:5])
#> | | mpg| cyl| disp| hp| drat|
#> |:-----------------|----:|---:|----:|---:|----:|
#> |Mazda RX4 | 21.0| 6| 160| 110| 3.90|
#> |Mazda RX4 Wag | 21.0| 6| 160| 110| 3.90|
#> |Datsun 710 | 22.8| 4| 108| 93| 3.85|
#> |Hornet 4 Drive | 21.4| 6| 258| 110| 3.08|
#> |Hornet Sportabout | 18.7| 8| 360| 175| 3.15|
#> |Valiant | 18.1| 6| 225| 105| 2.76|
# no inner padding
kable(d2, format = "pipe", padding = 0)
#> | | mpg|cyl|disp| hp|drat| wt| qsec| vs| am|gear|carb|
#> |:----------------|---:|--:|---:|--:|---:|----:|----:|--:|--:|---:|---:|
#> |Mazda RX4 |21.0| 6| 160|110|3.90|2.620|16.46| 0| 1| 4| 4|
#> |Mazda RX4 Wag |21.0| 6| 160|110|3.90|2.875|17.02| 0| 1| 4| 4|
#> |Datsun 710 |22.8| 4| 108| 93|3.85|2.320|18.61| 1| 1| 4| 1|
#> |Hornet 4 Drive |21.4| 6| 258|110|3.08|3.215|19.44| 1| 0| 3| 1|
#> |Hornet Sportabout|18.7| 8| 360|175|3.15|3.440|17.02| 0| 0| 3| 2|
#> |Valiant |18.1| 6| 225|105|2.76|3.460|20.22| 1| 0| 3| 1|
# more padding
kable(d2, format = "pipe", padding = 2)
#> | | mpg| cyl| disp| hp| drat| wt| qsec| vs| am| gear| carb|
#> |:------------------|-----:|----:|-----:|----:|-----:|------:|------:|---:|---:|-----:|-----:|
#> |Mazda RX4 | 21.0| 6| 160| 110| 3.90| 2.620| 16.46| 0| 1| 4| 4|
#> |Mazda RX4 Wag | 21.0| 6| 160| 110| 3.90| 2.875| 17.02| 0| 1| 4| 4|
#> |Datsun 710 | 22.8| 4| 108| 93| 3.85| 2.320| 18.61| 1| 1| 4| 1|
#> |Hornet 4 Drive | 21.4| 6| 258| 110| 3.08| 3.215| 19.44| 1| 0| 3| 1|
#> |Hornet Sportabout | 18.7| 8| 360| 175| 3.15| 3.440| 17.02| 0| 0| 3| 2|
#> |Valiant | 18.1| 6| 225| 105| 2.76| 3.460| 20.22| 1| 0| 3| 1|
kable(d1, format = "latex")
#> \begin{tabular}{r|r|r|r|l}
#> \hline
#> Sepal.Length & Sepal.Width & Petal.Length & Petal.Width & Species\\
#> \hline
#> 5.1 & 3.5 & 1.4 & 0.2 & setosa\\
#> \hline
#> 4.9 & 3.0 & 1.4 & 0.2 & setosa\\
#> \hline
#> 4.7 & 3.2 & 1.3 & 0.2 & setosa\\
#> \hline
#> 4.6 & 3.1 & 1.5 & 0.2 & setosa\\
#> \hline
#> 5.0 & 3.6 & 1.4 & 0.2 & setosa\\
#> \hline
#> 5.4 & 3.9 & 1.7 & 0.4 & setosa\\
#> \hline
#> \end{tabular}
kable(d1, format = "html")
#> <table class="table-full table-striped">
#> <thead>
#> <tr>
#> <th style="text-align:right;"> Sepal.Length </th>
#> <th style="text-align:right;"> Sepal.Width </th>
#> <th style="text-align:right;"> Petal.Length </th>
#> <th style="text-align:right;"> Petal.Width </th>
#> <th style="text-align:left;"> Species </th>
#> </tr>
#> </thead>
#> <tbody>
#> <tr>
#> <td style="text-align:right;"> 5.1 </td>
#> <td style="text-align:right;"> 3.5 </td>
#> <td style="text-align:right;"> 1.4 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 4.9 </td>
#> <td style="text-align:right;"> 3.0 </td>
#> <td style="text-align:right;"> 1.4 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 4.7 </td>
#> <td style="text-align:right;"> 3.2 </td>
#> <td style="text-align:right;"> 1.3 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 4.6 </td>
#> <td style="text-align:right;"> 3.1 </td>
#> <td style="text-align:right;"> 1.5 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 5.0 </td>
#> <td style="text-align:right;"> 3.6 </td>
#> <td style="text-align:right;"> 1.4 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 5.4 </td>
#> <td style="text-align:right;"> 3.9 </td>
#> <td style="text-align:right;"> 1.7 </td>
#> <td style="text-align:right;"> 0.4 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> </tbody>
#> </table>
kable(d1, format = "latex", caption = "Title of the table")
#> \begin{table}
#>
#> \caption{Title of the table}
#> \centering
#> \begin{tabular}[t]{r|r|r|r|l}
#> \hline
#> Sepal.Length & Sepal.Width & Petal.Length & Petal.Width & Species\\
#> \hline
#> 5.1 & 3.5 & 1.4 & 0.2 & setosa\\
#> \hline
#> 4.9 & 3.0 & 1.4 & 0.2 & setosa\\
#> \hline
#> 4.7 & 3.2 & 1.3 & 0.2 & setosa\\
#> \hline
#> 4.6 & 3.1 & 1.5 & 0.2 & setosa\\
#> \hline
#> 5.0 & 3.6 & 1.4 & 0.2 & setosa\\
#> \hline
#> 5.4 & 3.9 & 1.7 & 0.4 & setosa\\
#> \hline
#> \end{tabular}
#> \end{table}
kable(d1, format = "html", caption = "Title of the table")
#> <table class="table-full table-striped">
#> <caption>Title of the table</caption>
#> <thead>
#> <tr>
#> <th style="text-align:right;"> Sepal.Length </th>
#> <th style="text-align:right;"> Sepal.Width </th>
#> <th style="text-align:right;"> Petal.Length </th>
#> <th style="text-align:right;"> Petal.Width </th>
#> <th style="text-align:left;"> Species </th>
#> </tr>
#> </thead>
#> <tbody>
#> <tr>
#> <td style="text-align:right;"> 5.1 </td>
#> <td style="text-align:right;"> 3.5 </td>
#> <td style="text-align:right;"> 1.4 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 4.9 </td>
#> <td style="text-align:right;"> 3.0 </td>
#> <td style="text-align:right;"> 1.4 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 4.7 </td>
#> <td style="text-align:right;"> 3.2 </td>
#> <td style="text-align:right;"> 1.3 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 4.6 </td>
#> <td style="text-align:right;"> 3.1 </td>
#> <td style="text-align:right;"> 1.5 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 5.0 </td>
#> <td style="text-align:right;"> 3.6 </td>
#> <td style="text-align:right;"> 1.4 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 5.4 </td>
#> <td style="text-align:right;"> 3.9 </td>
#> <td style="text-align:right;"> 1.7 </td>
#> <td style="text-align:right;"> 0.4 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> </tbody>
#> </table>
# use the booktabs package
kable(mtcars, format = "latex", booktabs = TRUE)
#> \begin{tabular}{lrrrrrrrrrrr}
#> \toprule
#> & mpg & cyl & disp & hp & drat & wt & qsec & vs & am & gear & carb\\
#> \midrule
#> Mazda RX4 & 21.0 & 6 & 160.0 & 110 & 3.90 & 2.620 & 16.46 & 0 & 1 & 4 & 4\\
#> Mazda RX4 Wag & 21.0 & 6 & 160.0 & 110 & 3.90 & 2.875 & 17.02 & 0 & 1 & 4 & 4\\
#> Datsun 710 & 22.8 & 4 & 108.0 & 93 & 3.85 & 2.320 & 18.61 & 1 & 1 & 4 & 1\\
#> Hornet 4 Drive & 21.4 & 6 & 258.0 & 110 & 3.08 & 3.215 & 19.44 & 1 & 0 & 3 & 1\\
#> Hornet Sportabout & 18.7 & 8 & 360.0 & 175 & 3.15 & 3.440 & 17.02 & 0 & 0 & 3 & 2\\
#> \addlinespace
#> Valiant & 18.1 & 6 & 225.0 & 105 & 2.76 & 3.460 & 20.22 & 1 & 0 & 3 & 1\\
#> Duster 360 & 14.3 & 8 & 360.0 & 245 & 3.21 & 3.570 & 15.84 & 0 & 0 & 3 & 4\\
#> Merc 240D & 24.4 & 4 & 146.7 & 62 & 3.69 & 3.190 & 20.00 & 1 & 0 & 4 & 2\\
#> Merc 230 & 22.8 & 4 & 140.8 & 95 & 3.92 & 3.150 & 22.90 & 1 & 0 & 4 & 2\\
#> Merc 280 & 19.2 & 6 & 167.6 & 123 & 3.92 & 3.440 & 18.30 & 1 & 0 & 4 & 4\\
#> \addlinespace
#> Merc 280C & 17.8 & 6 & 167.6 & 123 & 3.92 & 3.440 & 18.90 & 1 & 0 & 4 & 4\\
#> Merc 450SE & 16.4 & 8 & 275.8 & 180 & 3.07 & 4.070 & 17.40 & 0 & 0 & 3 & 3\\
#> Merc 450SL & 17.3 & 8 & 275.8 & 180 & 3.07 & 3.730 & 17.60 & 0 & 0 & 3 & 3\\
#> Merc 450SLC & 15.2 & 8 & 275.8 & 180 & 3.07 & 3.780 & 18.00 & 0 & 0 & 3 & 3\\
#> Cadillac Fleetwood & 10.4 & 8 & 472.0 & 205 & 2.93 & 5.250 & 17.98 & 0 & 0 & 3 & 4\\
#> \addlinespace
#> Lincoln Continental & 10.4 & 8 & 460.0 & 215 & 3.00 & 5.424 & 17.82 & 0 & 0 & 3 & 4\\
#> Chrysler Imperial & 14.7 & 8 & 440.0 & 230 & 3.23 & 5.345 & 17.42 & 0 & 0 & 3 & 4\\
#> Fiat 128 & 32.4 & 4 & 78.7 & 66 & 4.08 & 2.200 & 19.47 & 1 & 1 & 4 & 1\\
#> Honda Civic & 30.4 & 4 & 75.7 & 52 & 4.93 & 1.615 & 18.52 & 1 & 1 & 4 & 2\\
#> Toyota Corolla & 33.9 & 4 & 71.1 & 65 & 4.22 & 1.835 & 19.90 & 1 & 1 & 4 & 1\\
#> \addlinespace
#> Toyota Corona & 21.5 & 4 & 120.1 & 97 & 3.70 & 2.465 & 20.01 & 1 & 0 & 3 & 1\\
#> Dodge Challenger & 15.5 & 8 & 318.0 & 150 & 2.76 & 3.520 & 16.87 & 0 & 0 & 3 & 2\\
#> AMC Javelin & 15.2 & 8 & 304.0 & 150 & 3.15 & 3.435 & 17.30 & 0 & 0 & 3 & 2\\
#> Camaro Z28 & 13.3 & 8 & 350.0 & 245 & 3.73 & 3.840 & 15.41 & 0 & 0 & 3 & 4\\
#> Pontiac Firebird & 19.2 & 8 & 400.0 & 175 & 3.08 & 3.845 & 17.05 & 0 & 0 & 3 & 2\\
#> \addlinespace
#> Fiat X1-9 & 27.3 & 4 & 79.0 & 66 & 4.08 & 1.935 & 18.90 & 1 & 1 & 4 & 1\\
#> Porsche 914-2 & 26.0 & 4 & 120.3 & 91 & 4.43 & 2.140 & 16.70 & 0 & 1 & 5 & 2\\
#> Lotus Europa & 30.4 & 4 & 95.1 & 113 & 3.77 & 1.513 & 16.90 & 1 & 1 & 5 & 2\\
#> Ford Pantera L & 15.8 & 8 & 351.0 & 264 & 4.22 & 3.170 & 14.50 & 0 & 1 & 5 & 4\\
#> Ferrari Dino & 19.7 & 6 & 145.0 & 175 & 3.62 & 2.770 & 15.50 & 0 & 1 & 5 & 6\\
#> \addlinespace
#> Maserati Bora & 15.0 & 8 & 301.0 & 335 & 3.54 & 3.570 & 14.60 & 0 & 1 & 5 & 8\\
#> Volvo 142E & 21.4 & 4 & 121.0 & 109 & 4.11 & 2.780 & 18.60 & 1 & 1 & 4 & 2\\
#> \bottomrule
#> \end{tabular}
# use the longtable package
kable(matrix(1000, ncol = 5), format = "latex", digits = 2, longtable = TRUE)
#> \begin{longtable}{r|r|r|r|r}
#> \hline
#> 1000 & 1000 & 1000 & 1000 & 1000\\
#> \hline
#> \end{longtable}
# change LaTeX default table environment
kable(d1, format = "latex", caption = "My table", table.envir = "table*")
#> \begin{table*}
#>
#> \caption{My table}
#> \centering
#> \begin{tabular}[t]{r|r|r|r|l}
#> \hline
#> Sepal.Length & Sepal.Width & Petal.Length & Petal.Width & Species\\
#> \hline
#> 5.1 & 3.5 & 1.4 & 0.2 & setosa\\
#> \hline
#> 4.9 & 3.0 & 1.4 & 0.2 & setosa\\
#> \hline
#> 4.7 & 3.2 & 1.3 & 0.2 & setosa\\
#> \hline
#> 4.6 & 3.1 & 1.5 & 0.2 & setosa\\
#> \hline
#> 5.0 & 3.6 & 1.4 & 0.2 & setosa\\
#> \hline
#> 5.4 & 3.9 & 1.7 & 0.4 & setosa\\
#> \hline
#> \end{tabular}
#> \end{table*}
# add some table attributes
kable(d1, format = "html", table.attr = "id=\"mytable\"")
#> <table id="mytable">
#> <thead>
#> <tr>
#> <th style="text-align:right;"> Sepal.Length </th>
#> <th style="text-align:right;"> Sepal.Width </th>
#> <th style="text-align:right;"> Petal.Length </th>
#> <th style="text-align:right;"> Petal.Width </th>
#> <th style="text-align:left;"> Species </th>
#> </tr>
#> </thead>
#> <tbody>
#> <tr>
#> <td style="text-align:right;"> 5.1 </td>
#> <td style="text-align:right;"> 3.5 </td>
#> <td style="text-align:right;"> 1.4 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 4.9 </td>
#> <td style="text-align:right;"> 3.0 </td>
#> <td style="text-align:right;"> 1.4 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 4.7 </td>
#> <td style="text-align:right;"> 3.2 </td>
#> <td style="text-align:right;"> 1.3 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 4.6 </td>
#> <td style="text-align:right;"> 3.1 </td>
#> <td style="text-align:right;"> 1.5 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 5.0 </td>
#> <td style="text-align:right;"> 3.6 </td>
#> <td style="text-align:right;"> 1.4 </td>
#> <td style="text-align:right;"> 0.2 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> <tr>
#> <td style="text-align:right;"> 5.4 </td>
#> <td style="text-align:right;"> 3.9 </td>
#> <td style="text-align:right;"> 1.7 </td>
#> <td style="text-align:right;"> 0.4 </td>
#> <td style="text-align:left;"> setosa </td>
#> </tr>
#> </tbody>
#> </table>
# reST output
kable(d2, format = "rst")
#> ================= ==== === ==== === ==== ===== ===== === === ==== ====
#> \ mpg cyl disp hp drat wt qsec vs am gear carb
#> ================= ==== === ==== === ==== ===== ===== === === ==== ====
#> Mazda RX4 21.0 6 160 110 3.90 2.620 16.46 0 1 4 4
#> Mazda RX4 Wag 21.0 6 160 110 3.90 2.875 17.02 0 1 4 4
#> Datsun 710 22.8 4 108 93 3.85 2.320 18.61 1 1 4 1
#> Hornet 4 Drive 21.4 6 258 110 3.08 3.215 19.44 1 0 3 1
#> Hornet Sportabout 18.7 8 360 175 3.15 3.440 17.02 0 0 3 2
#> Valiant 18.1 6 225 105 2.76 3.460 20.22 1 0 3 1
#> ================= ==== === ==== === ==== ===== ===== === === ==== ====
# no row names
kable(d2, format = "rst", row.names = FALSE)
#> ==== === ==== === ==== ===== ===== === === ==== ====
#> mpg cyl disp hp drat wt qsec vs am gear carb
#> ==== === ==== === ==== ===== ===== === === ==== ====
#> 21.0 6 160 110 3.90 2.620 16.46 0 1 4 4
#> 21.0 6 160 110 3.90 2.875 17.02 0 1 4 4
#> 22.8 4 108 93 3.85 2.320 18.61 1 1 4 1
#> 21.4 6 258 110 3.08 3.215 19.44 1 0 3 1
#> 18.7 8 360 175 3.15 3.440 17.02 0 0 3 2
#> 18.1 6 225 105 2.76 3.460 20.22 1 0 3 1
#> ==== === ==== === ==== ===== ===== === === ==== ====
# Pandoc simple tables
kable(d2, format = "simple", caption = "Title of the table")
#> Table: Title of the table
#>
#> mpg cyl disp hp drat wt qsec vs am gear carb
#> ------------------ ----- ---- ----- ---- ----- ------ ------ --- --- ----- -----
#> Mazda RX4 21.0 6 160 110 3.90 2.620 16.46 0 1 4 4
#> Mazda RX4 Wag 21.0 6 160 110 3.90 2.875 17.02 0 1 4 4
#> Datsun 710 22.8 4 108 93 3.85 2.320 18.61 1 1 4 1
#> Hornet 4 Drive 21.4 6 258 110 3.08 3.215 19.44 1 0 3 1
#> Hornet Sportabout 18.7 8 360 175 3.15 3.440 17.02 0 0 3 2
#> Valiant 18.1 6 225 105 2.76 3.460 20.22 1 0 3 1
# format numbers using , as decimal point, and ' as thousands separator
x = as.data.frame(matrix(rnorm(60, 1e+06, 10000), 10))
kable(x, format.args = list(decimal.mark = ",", big.mark = "'"))
#> | V1| V2| V3| V4| V5| V6|
#> |-----------:|-----------:|-----------:|-----------:|-----------:|-----------:|
#> | 1'001'726,9| 1'000'495,0| 1'017'602,6| 1'011'984,8| 992'529,9| 973'084,1|
#> | 988'496,5| 992'841,0| 992'602,5| 998'981,9| 990'555,7| 995'190,5|
#> | 1'012'801,8| 1'014'032,0| 985'668,1| 1'001'606,6| 996'934,3| 1'016'672,7|
#> | 991'094,1| 1'017'361,8| 1'004'195,1| 1'013'547,1| 1'010'111,5| 990'039,3|
#> | 994'912,7| 987'465,7| 989'343,6| 1'005'625,6| 963'407,1| 1'008'348,3|
#> | 982'481,2| 1'006'239,8| 993'145,8| 999'690,3| 986'099,6| 999'815,0|
#> | 1'017'965,1| 995'781,4| 1'007'733,4| 998'756,7| 1'000'697,7| 1'011'236,9|
#> | 999'871,0| 993'958,3| 1'019'541,9| 993'293,0| 985'962,3| 1'002'134,4|
#> | 1'005'735,2| 1'027'561,0| 1'011'495,1| 984'374,7| 1'009'872,8| 1'004'260,8|
#> | 988'645,8| 979'612,5| 980'454,8| 1'003'594,7| 999'042,3| 994'852,5|
# save the value
x = kable(d2, format = "html")
cat(x, sep = "\n")
#> <table class="table-full table-striped">
#> <thead>
#> <tr>
#> <th style="text-align:left;"> </th>
#> <th style="text-align:right;"> mpg </th>
#> <th style="text-align:right;"> cyl </th>
#> <th style="text-align:right;"> disp </th>
#> <th style="text-align:right;"> hp </th>
#> <th style="text-align:right;"> drat </th>
#> <th style="text-align:right;"> wt </th>
#> <th style="text-align:right;"> qsec </th>
#> <th style="text-align:right;"> vs </th>
#> <th style="text-align:right;"> am </th>
#> <th style="text-align:right;"> gear </th>
#> <th style="text-align:right;"> carb </th>
#> </tr>
#> </thead>
#> <tbody>
#> <tr>
#> <td style="text-align:left;"> Mazda RX4 </td>
#> <td style="text-align:right;"> 21.0 </td>
#> <td style="text-align:right;"> 6 </td>
#> <td style="text-align:right;"> 160 </td>
#> <td style="text-align:right;"> 110 </td>
#> <td style="text-align:right;"> 3.90 </td>
#> <td style="text-align:right;"> 2.620 </td>
#> <td style="text-align:right;"> 16.46 </td>
#> <td style="text-align:right;"> 0 </td>
#> <td style="text-align:right;"> 1 </td>
#> <td style="text-align:right;"> 4 </td>
#> <td style="text-align:right;"> 4 </td>
#> </tr>
#> <tr>
#> <td style="text-align:left;"> Mazda RX4 Wag </td>
#> <td style="text-align:right;"> 21.0 </td>
#> <td style="text-align:right;"> 6 </td>
#> <td style="text-align:right;"> 160 </td>
#> <td style="text-align:right;"> 110 </td>
#> <td style="text-align:right;"> 3.90 </td>
#> <td style="text-align:right;"> 2.875 </td>
#> <td style="text-align:right;"> 17.02 </td>
#> <td style="text-align:right;"> 0 </td>
#> <td style="text-align:right;"> 1 </td>
#> <td style="text-align:right;"> 4 </td>
#> <td style="text-align:right;"> 4 </td>
#> </tr>
#> <tr>
#> <td style="text-align:left;"> Datsun 710 </td>
#> <td style="text-align:right;"> 22.8 </td>
#> <td style="text-align:right;"> 4 </td>
#> <td style="text-align:right;"> 108 </td>
#> <td style="text-align:right;"> 93 </td>
#> <td style="text-align:right;"> 3.85 </td>
#> <td style="text-align:right;"> 2.320 </td>
#> <td style="text-align:right;"> 18.61 </td>
#> <td style="text-align:right;"> 1 </td>
#> <td style="text-align:right;"> 1 </td>
#> <td style="text-align:right;"> 4 </td>
#> <td style="text-align:right;"> 1 </td>
#> </tr>
#> <tr>
#> <td style="text-align:left;"> Hornet 4 Drive </td>
#> <td style="text-align:right;"> 21.4 </td>
#> <td style="text-align:right;"> 6 </td>
#> <td style="text-align:right;"> 258 </td>
#> <td style="text-align:right;"> 110 </td>
#> <td style="text-align:right;"> 3.08 </td>
#> <td style="text-align:right;"> 3.215 </td>
#> <td style="text-align:right;"> 19.44 </td>
#> <td style="text-align:right;"> 1 </td>
#> <td style="text-align:right;"> 0 </td>
#> <td style="text-align:right;"> 3 </td>
#> <td style="text-align:right;"> 1 </td>
#> </tr>
#> <tr>
#> <td style="text-align:left;"> Hornet Sportabout </td>
#> <td style="text-align:right;"> 18.7 </td>
#> <td style="text-align:right;"> 8 </td>
#> <td style="text-align:right;"> 360 </td>
#> <td style="text-align:right;"> 175 </td>
#> <td style="text-align:right;"> 3.15 </td>
#> <td style="text-align:right;"> 3.440 </td>
#> <td style="text-align:right;"> 17.02 </td>
#> <td style="text-align:right;"> 0 </td>
#> <td style="text-align:right;"> 0 </td>
#> <td style="text-align:right;"> 3 </td>
#> <td style="text-align:right;"> 2 </td>
#> </tr>
#> <tr>
#> <td style="text-align:left;"> Valiant </td>
#> <td style="text-align:right;"> 18.1 </td>
#> <td style="text-align:right;"> 6 </td>
#> <td style="text-align:right;"> 225 </td>
#> <td style="text-align:right;"> 105 </td>
#> <td style="text-align:right;"> 2.76 </td>
#> <td style="text-align:right;"> 3.460 </td>
#> <td style="text-align:right;"> 20.22 </td>
#> <td style="text-align:right;"> 1 </td>
#> <td style="text-align:right;"> 0 </td>
#> <td style="text-align:right;"> 3 </td>
#> <td style="text-align:right;"> 1 </td>
#> </tr>
#> </tbody>
#> </table>
# can also set options(knitr.table.format = 'html') so that the output is HTML
# multiple tables via either kable(list(x1, x2)) or kables(list(kable(x1),
# kable(x2)))
kable(list(d1, d2), caption = "A tale of two tables")
#> Table: A tale of two tables
#>
#> | Sepal.Length| Sepal.Width| Petal.Length| Petal.Width|Species |
#> |------------:|-----------:|------------:|-----------:|:-------|
#> | 5.1| 3.5| 1.4| 0.2|setosa |
#> | 4.9| 3.0| 1.4| 0.2|setosa |
#> | 4.7| 3.2| 1.3| 0.2|setosa |
#> | 4.6| 3.1| 1.5| 0.2|setosa |
#> | 5.0| 3.6| 1.4| 0.2|setosa |
#> | 5.4| 3.9| 1.7| 0.4|setosa |
#>
#> | | mpg| cyl| disp| hp| drat| wt| qsec| vs| am| gear| carb|
#> |:-----------------|----:|---:|----:|---:|----:|-----:|-----:|--:|--:|----:|----:|
#> |Mazda RX4 | 21.0| 6| 160| 110| 3.90| 2.620| 16.46| 0| 1| 4| 4|
#> |Mazda RX4 Wag | 21.0| 6| 160| 110| 3.90| 2.875| 17.02| 0| 1| 4| 4|
#> |Datsun 710 | 22.8| 4| 108| 93| 3.85| 2.320| 18.61| 1| 1| 4| 1|
#> |Hornet 4 Drive | 21.4| 6| 258| 110| 3.08| 3.215| 19.44| 1| 0| 3| 1|
#> |Hornet Sportabout | 18.7| 8| 360| 175| 3.15| 3.440| 17.02| 0| 0| 3| 2|
#> |Valiant | 18.1| 6| 225| 105| 2.76| 3.460| 20.22| 1| 0| 3| 1|
kables(list(kable(d1, align = "l"), kable(d2)), caption = "A tale of two tables")
#> Table: A tale of two tables
#>
#> |Sepal.Length |Sepal.Width |Petal.Length |Petal.Width |Species |
#> |:------------|:-----------|:------------|:-----------|:-------|
#> |5.1 |3.5 |1.4 |0.2 |setosa |
#> |4.9 |3.0 |1.4 |0.2 |setosa |
#> |4.7 |3.2 |1.3 |0.2 |setosa |
#> |4.6 |3.1 |1.5 |0.2 |setosa |
#> |5.0 |3.6 |1.4 |0.2 |setosa |
#> |5.4 |3.9 |1.7 |0.4 |setosa |
#>
#> | | mpg| cyl| disp| hp| drat| wt| qsec| vs| am| gear| carb|
#> |:-----------------|----:|---:|----:|---:|----:|-----:|-----:|--:|--:|----:|----:|
#> |Mazda RX4 | 21.0| 6| 160| 110| 3.90| 2.620| 16.46| 0| 1| 4| 4|
#> |Mazda RX4 Wag | 21.0| 6| 160| 110| 3.90| 2.875| 17.02| 0| 1| 4| 4|
#> |Datsun 710 | 22.8| 4| 108| 93| 3.85| 2.320| 18.61| 1| 1| 4| 1|
#> |Hornet 4 Drive | 21.4| 6| 258| 110| 3.08| 3.215| 19.44| 1| 0| 3| 1|
#> |Hornet Sportabout | 18.7| 8| 360| 175| 3.15| 3.440| 17.02| 0| 0| 3| 2|
#> |Valiant | 18.1| 6| 225| 105| 2.76| 3.460| 20.22| 1| 0| 3| 1|
This function takes an input file, extracts the R code in it according to a
list of patterns, evaluates the code and writes the output in another file.
It can also tangle R source code from the input document (purl()
is a
wrapper to knit(..., tangle = TRUE)
). The knitr.purl.inline
option can be used to also tangle the code of inline expressions (disabled by
default).
knit(
input,
output = NULL,
tangle = FALSE,
text = NULL,
quiet = FALSE,
envir = parent.frame(),
encoding = "UTF-8"
)
purl(..., documentation = 1L)
input |
Path to the input file. |
output |
Path to the output file for |
tangle |
Boolean; whether to tangle the R code from the input file (like
|
text |
A character vector. This is an alternative way to provide the input file. |
quiet |
Boolean; suppress the progress bar and messages? |
envir |
Environment in which code chunks are to be evaluated, for
example, |
encoding |
Encoding of the input file; always assumed to be UTF-8 (i.e., this argument is effectively ignored). |
... |
arguments passed to |
documentation |
An integer specifying the level of documentation to add to
the tangled script. |
For most of the time, it is not necessary to set any options outside the
input document; in other words, a single call like
knit('my_input.Rnw')
is usually enough. This function will try to
determine many internal settings automatically. For the sake of
reproducibility, it is better practice to include the options inside the
input document (to be self-contained), instead of setting them before
knitting the document.
First the filename of the output document is determined in this way:
‘foo.Rnw’ generates ‘foo.tex’, and other filename extensions like
‘.Rtex’, ‘.Rhtml’ (‘.Rhtm’) and ‘.Rmd’
(‘.Rmarkdown’) will generate ‘.tex’, ‘.html’ and ‘.md’
respectively. For other types of files, if the filename contains
‘_knit_’, this part will be removed in the output file, e.g.,
‘foo_knit_.html’ creates the output ‘foo.html’; if ‘_knit_’ is
not found in the filename, ‘foo.ext’ will produce ‘foo.txt’ if
ext
is not txt
, otherwise the output is ‘foo-out.txt’. If
tangle = TRUE
, ‘foo.ext’ generates an R script ‘foo.R’.
We need a set of syntax to identify special markups for R code chunks and R
options, etc. The syntax is defined in a pattern list. All built-in pattern
lists can be found in all_patterns
(call it apat
). First
knitr will try to decide the pattern list based on the filename
extension of the input document, e.g. ‘Rnw’ files use the list
apat$rnw
, ‘tex’ uses the list apat$tex
, ‘brew’ uses
apat$brew
and HTML files use apat$html
; for unkown extensions,
the content of the input document is matched against all pattern lists to
automatically determine which pattern list is being used. You can also
manually set the pattern list using the knit_patterns
object or
the pat_rnw
series functions in advance and knitr will
respect the setting.
According to the output format (opts_knit$get('out.format')
), a set of
output hooks will be set to mark up results from R (see
render_latex
). The output format can be LaTeX, Sweave and HTML,
etc. The output hooks decide how to mark up the results (you can customize
the hooks).
The name knit
comes from its counterpart ‘weave’ (as in Sweave),
and the name purl
(as ‘tangle’ in Stangle) comes from a knitting
method ‘knit one, purl one’.
If the input document has child documents, they will also be compiled
recursively. See knit_child
.
See the package website and manuals in the references to know more about knitr, including the full documentation of chunk options and demos, etc.
The compiled document is written into the output file, and the path
of the output file is returned. If the text
argument is not
NULL
, the compiled output is returned as a character vector. In
other words, if you provide a file input, you get an output filename; if
you provide a character vector input, you get a character vector output.
The working directory when evaluating R code chunks is the directory of
the input document by default, so if the R code involves external files
(like read.table()
), it is better to put these files under the same
directory of the input document so that we can use relative paths. However,
it is possible to change this directory with the package option
opts_knit$set(root.dir = ...)
so all paths in code chunks are
relative to this root.dir
. It is not recommended to change the
working directory via setwd()
in a code chunk, because it may
lead to terrible consequences (e.g. figure and cache files may be written
to wrong places). If you do use setwd()
, please note that
knitr will always restore the working directory to the original one.
Whenever you feel confused, print getwd()
in a code chunk to see
what the working directory really is.
If the output
argument is a file path, it is strongly recommended to
be in the current working directory (e.g. ‘foo.tex’ instead of
‘somewhere/foo.tex’), especially when the output has external
dependencies such as figure files. If you want to write the output to a
different directory, it is recommended to set the working directory to that
directory before you knit a document. For example, if the source document
is ‘foo.Rmd’ and the expected output is ‘out/foo.md’, you can
write setwd('out/'); knit('../foo.Rmd')
instead of
knit('foo.Rmd', 'out/foo.md')
.
N.B. There is no guarantee that the R script generated by purl()
can
reproduce the computation done in knit()
. The knit()
process
can be fairly complicated (special values for chunk options, custom chunk
hooks, computing engines besides R, and the envir
argument, etc). If
you want to reproduce the computation in a report generated by
knit()
, be sure to use knit()
, instead of merely executing
the R script generated by purl()
. This seems to be obvious, but some
people
do not
get it.
Package homepage: https://yihui.org/knitr/. The knitr main manual: and graphics manual.
See citation('knitr')
for the citation information.
library(knitr)
(f = system.file("examples", "knitr-minimal.Rnw", package = "knitr"))
#> [1] "/home/runner/work/_temp/Library/knitr/examples/knitr-minimal.Rnw"
knit(f) # compile to tex
#> 1/7
#> 2/7 [setup]
#> 3/7
#> 4/7 [boring-random]
#> 5/7
#> 6/7 [boring-plots]
#> 7/7
#> [1] "knitr-minimal.tex"
purl(f) # tangle R code
#> 1/7
#> 2/7 [setup]
#> 3/7
#> 4/7 [boring-random]
#> 5/7
#> 6/7 [boring-plots]
#> 7/7
#> [1] "knitr-minimal.R"
purl(f, documentation = 0) # extract R code only
#> 1/7
#> 2/7 [setup]
#> 3/7
#> 4/7 [boring-random]
#> 5/7
#> 6/7 [boring-plots]
#> 7/7
#> [1] "knitr-minimal.R"
purl(f, documentation = 2) # also include documentation
#> 1/7
#> 2/7 [setup]
#> 3/7
#> 4/7 [boring-random]
#> 5/7
#> 6/7 [boring-plots]
#> 7/7
#> [1] "knitr-minimal.R"
unlink(c("knitr-minimal.tex", "knitr-minimal.R", "figure"), recursive = TRUE)
This is a convenience function to knit the input markdown source and call
markdown::mark_html()
in the markdown
package to convert the result to HTML.
knit2html(
input,
output = NULL,
...,
envir = parent.frame(),
text = NULL,
quiet = FALSE,
encoding = "UTF-8",
force_v1 = getOption("knitr.knit2html.force_v1", FALSE)
)
input |
Path to the input file. |
output |
Path to the output file for |
... |
Options passed to
|
envir |
Environment in which code chunks are to be evaluated, for
example, |
text |
A character vector. This is an alternative way to provide the input file. |
quiet |
Boolean; suppress the progress bar and messages? |
encoding |
Encoding of the input file; always assumed to be UTF-8 (i.e., this argument is effectively ignored). |
force_v1 |
Boolean; whether to force rendering the input document as an R Markdown v1 document, even if it is for v2. |
If the argument text
is NULL, a character string (HTML code)
is returned; otherwise the result is written into a file and the filename
is returned.
The markdown package is for R Markdown v1, which is much less
powerful than R Markdown v2, i.e. the rmarkdown package
(https://rmarkdown.rstudio.com). To render R Markdown v2 documents to
HTML, please use rmarkdown::render()
instead.
# a minimal example
writeLines(c("# hello markdown", "```{r hello-random, echo=TRUE}", "rnorm(5)", "```"),
"test.Rmd")
knit2html("test.Rmd")
#> 1/2
#> 2/2 [hello-random]
if (interactive()) browseURL("test.html")
unlink(c("test.Rmd", "test.html", "test.md"))
knit()
and
PandocKnits the input file and compiles to an output format using Pandoc.
knit2pandoc(
input,
output = NULL,
tangle = FALSE,
text = NULL,
quiet = FALSE,
envir = parent.frame(),
to = "html",
pandoc_wrapper = NULL,
...,
encoding = "UTF-8"
)
input |
Path to the input file. |
output |
Path to the output file for |
tangle |
Boolean; whether to tangle the R code from the input file (like
|
text |
A character vector. This is an alternative way to provide the input file. |
quiet |
Boolean; suppress the progress bar and messages? |
envir |
Environment in which code chunks are to be evaluated, for
example, |
to |
Character string giving the Pandoc output format to use. |
pandoc_wrapper |
An R function used to call Pandoc. If |
... |
Options to be passed to the |
encoding |
Ignored (always assumes UTF-8). |
Returns the output of the pandoc_wrapper
function.
Trevor L. Davis
Knit the input Rnw or Rrst document, and compile to PDF using
tinytex::latexmk()
or rst2pdf()
.
knit2pdf(
input,
output = NULL,
compiler = NULL,
envir = parent.frame(),
quiet = FALSE,
...
)
input |
Path to the input file. |
output |
Path to the output file for |
compiler |
A character string giving the LaTeX engine used to compile
the tex document to PDF. For an Rrst file, setting |
envir |
Environment in which code chunks are to be evaluated, for
example, |
quiet |
Boolean; suppress the progress bar and messages? |
... |
The filename of the PDF file.
The output
argument specifies the output filename to be passed
to the PDF compiler (e.g. a tex document) instead of the PDF filename.
Ramnath Vaidyanathan, Alex Zvoleff and Yihui Xie
#' compile with xelatex
## knit2pdf(..., compiler = 'xelatex')
#' compile a reST file with rst2pdf
## knit2pdf(..., compiler = 'rst2pdf')
This function is a wrapper around the RWordPress package. It compiles an R Markdown document to HTML and post the results to WordPress. Please note that RWordPress has not been updated for several years, which is not a good sign. For blogging with R, you may want to try the blogdown package instead.
knit2wp(
input,
title = "A post from knitr",
...,
envir = parent.frame(),
shortcode = FALSE,
action = c("newPost", "editPost", "newPage"),
postid,
publish = TRUE
)
input |
Filename of the Rmd document. |
title |
Title of the post. |
... |
Other meta information of the post, e.g. |
envir |
Environment in which code chunks are to be evaluated, for
example, |
shortcode |
A length-2 logical vector: whether to use the shortcode
‘[sourcecode lang='lang']’, which can be useful to WordPress.com users
for syntax highlighting of source code and output. The first element
applies to source code, and the second applies to text output. By default,
both are |
action |
Whether to create a new post, update an existing post, or create a new page. |
postid |
If |
publish |
Boolean: publish the post immediately? |
This function will convert the encoding of the post and the title to
UTF-8 internally. If you have additional data to send to WordPress (e.g.
keywords and categories), you may have to manually convert them to the
UTF-8 encoding with the iconv(x, to = 'UTF-8')
function
(especially when using Windows).
William K. Morris, Yihui Xie, and Jared Lander
https://yihui.org/knitr/demo/wordpress/
# see the reference
This function knits a child document and returns a character string to input
the result into the main document. It is designed to be used in the chunk
option child
and serves as the alternative to the
SweaveInput
command in Sweave.
knit_child(..., options = NULL, envir = knit_global())
... |
Arguments passed to |
options |
A list of chunk options to be used as global options inside
the child document. When one uses the |
envir |
Environment in which code chunks are to be evaluated, for
example, |
A character string of the content of the compiled child document is returned as a character string so it can be written back to the parent document directly.
This function is not supposed be called directly like
knit()
; instead it must be placed in a parent document to let
knit()
call it indirectly.
The path of the child document is determined relative to the parent document.
https://yihui.org/knitr/demo/child/
# you can write \Sexpr{knit_child('child-doc.Rnw')} in an Rnw file 'main.Rnw'
# to input results from child-doc.Rnw in main.tex
# comment out the child doc by \Sexpr{knit_child('child-doc.Rnw', eval =
# FALSE)}
This object provides methods to manage code (as character vectors) in all
chunks in knitr source documents. For example,
knitr::knit_code$get()
returns a named list of all code chunks (the
names are chunk labels), and knitr::knit_code$get('foo')
returns the
character vector of the code in the chunk with the label foo
.
knit_code
An object of class list
of length 7.
The methods on this object include the set()
method (i.e., you
could do something like knitr::knit_code$set(foo = "'my precious new
code'")
), but we recommend that you do not use this method to modify the
content of code chunks, unless you are
as creative as Emi
Tanaka and know what you are doing.
This object controls how to execute the code from languages other than R
(when the chunk option engine
is not 'R'
). Each component in
this object is a function that takes a list of current chunk options
(including the source code) and returns a character string to be written into
the output.
knit_engines
An object of class list
of length 7.
The engine function has one argument options
: the source code of the
current chunk is in options$code
. Usually we can call external
programs to run the code via system2
. Other chunk options are
also contained in this argument, e.g. options$echo
and
options$eval
, etc.
In most cases, options$engine
can be directly used in command line to
execute the code, e.g. python
or ruby
, but sometimes we may
want to specify the path of the engine program, in which case we can pass it
through the engine.path
option. For example, engine='ruby',
engine.path='/usr/bin/ruby1.9.1'
. Additional command line arguments can be
passed through options$engine.opts
, e.g. engine='ruby',
engine.opts='-v'
.
See str(knitr::knit_engines$get())
for a list of built-in language
engines.
The Leiningen engine lein
requires lein-exec plugin; see
https://github.com/yihui/knitr/issues/1176 for details.
Usage: https://yihui.org/knitr/objects/; examples: https://yihui.org/knitr/demo/engines/
knit_engines$get("python")
#> function (options)
#> {
#> if (isFALSE(options$python.reticulate)) {
#> eng_interpreted(options)
#> }
#> else {
#> if (!loadable("reticulate"))
#> warning2("The 'python' engine in knitr requires the reticulate package. ",
#> "If you do not want to use the reticulate package, set the chunk option ",
#> "python.reticulate = FALSE.")
#> reticulate::eng_python(options)
#> }
#> }
#> <environment: namespace:knitr>
knit_engines$get("awk")
#> function (options)
#> {
#> engine = options$engine
#> code = if (engine %in% c("highlight", "Rscript", "sas", "haskell",
#> "stata")) {
#> f = wd_tempfile(engine, switch(engine, sas = ".sas",
#> Rscript = ".R", stata = ".do", ".txt"))
#> write_utf8(c(switch(engine, sas = "OPTIONS NONUMBER NODATE PAGESIZE = MAX FORMCHAR = '|----|+|---+=|-/<>*' FORMDLIM=' ';title;",
#> NULL), options$code), f)
#> on.exit(unlink(f), add = TRUE)
#> switch(engine, haskell = paste("-e", shQuote(paste(":script",
#> f))), sas = {
#> logf = sub("[.]sas$", ".lst", f)
#> on.exit(unlink(c(logf, sub("[.]sas$", ".log", f))),
#> add = TRUE)
#> f
#> }, stata = {
#> logf = sub("[.]do$", ".log", f)
#> on.exit(unlink(c(logf)), add = TRUE)
#> sprintf(switch(Sys.info()[["sysname"]], Windows = "/q /e do %s",
#> Darwin = paste("-q < %s >", shQuote(xfun::normalize_path(logf))),
#> Linux = "-q -e do %s", "-q -b do %s"), shQuote(normalizePath(f)))
#> }, f)
#> }
#> else paste(switch(engine, bash = "-c", coffee = "-e", groovy = "-e",
#> lein = "exec -ep", mysql = "-e", node = "-e", octave = "--eval",
#> perl = "-E", php = "-r", psql = "-c", python = "-c",
#> ruby = "-e", scala = "-e", sh = "-c", zsh = "-c", NULL),
#> shQuote(one_string(options$code)))
#> opts = get_engine_opts(options$engine.opts, engine)
#> code = if (engine %in% c("awk", "gawk", "sed", "sas", "psql",
#> "mysql"))
#> paste(code, opts)
#> else paste(opts, code)
#> cmd = get_engine_path(options$engine.path, engine)
#> out = if (options$eval) {
#> if (options$message)
#> message("running: ", cmd, " ", code)
#> tryCatch(system2(cmd, code, stdout = TRUE, stderr = TRUE,
#> env = options$engine.env), error = function(e) {
#> if (!options$error)
#> stop(e)
#> paste("Error in running command", cmd)
#> })
#> }
#> else ""
#> if (!options$error && !is.null(attr(out, "status")))
#> stop(one_string(out))
#> if (options$eval && engine %in% c("sas", "stata") && file.exists(logf))
#> out = c(read_utf8(logf), out)
#> engine_output(options, options$code, out)
#> }
#> <environment: namespace:knitr>
names(knit_engines$get())
#> [1] "awk" "bash" "coffee" "gawk" "groovy" "haskell" "lein"
#> [8] "mysql" "node" "octave" "perl" "php" "psql" "Rscript"
#> [15] "ruby" "sas" "scala" "sed" "sh" "stata" "zsh"
#> [22] "asis" "asy" "block" "block2" "bslib" "c" "cat"
#> [29] "cc" "comment" "css" "ditaa" "dot" "embed" "eviews"
#> [36] "exec" "fortran" "fortran95" "go" "highlight" "js" "julia"
#> [43] "python" "R" "Rcpp" "sass" "scss" "sql" "stan"
#> [50] "targets" "tikz" "verbatim"
Sometimes we may want to exit the knitting process early, and completely
ignore the rest of the document. This function provides a mechanism to
terminate knit()
.
knit_exit(append, fully = TRUE)
append |
A character vector to be appended to the results from
|
fully |
Whether to fully exit the knitting process if |
Invisible NULL
. An internal signal is set up (as a side
effect) to notify knit()
to quit as if it had reached the end of the
document.
# see https://github.com/yihui/knitr-examples/blob/master/096-knit-exit.Rmd
This function expands a template based on the R expressions in {{}}
(this tag can be customized by the delim
argument). These expressions
are extracted, evaluated and replaced by their values in the original
template.
knit_expand(file, ..., text = read_utf8(file), delim = c("{{", "}}"))
file |
The template file. |
... |
A list of variables to be used for the code in the template; note that the variables will be searched for in the parent frame as well. |
text |
Character vector of lines of code. An alternative way to specify
the template code directly. If |
delim |
A pair of opening and closing delimiters for the templating tags. |
A character vector, with the tags evaluated and replaced by their values.
This function was inspired by the pyexpander and m4 (http://www.gnu.org/software/m4/), thanks to Frank Harrell.
# see the knit_expand vignette
if (interactive()) browseVignettes(package = "knitr")
When performing spell checking on source documents, we may need to skip R
code chunks and inline R expressions, because many R functions and symbols
are likely to be identified as typos. This function is designed for the
filter
argument of aspell()
to filter out code chunks
and inline expressions.
knit_filter(ifile, encoding = "UTF-8")
ifile |
Filename of the source document. |
encoding |
Ignored (the file |
A character vector of the file content, excluding code chunks and inline expressions.
library(knitr)
knitr_example = function(...) system.file("examples", ..., package = "knitr")
if (Sys.which("aspell") != "") {
# -t means the TeX mode
utils::aspell(knitr_example("knitr-minimal.Rnw"), knit_filter, control = "-t")
# -H is the HTML mode
utils::aspell(knitr_example("knitr-minimal.Rmd"), knit_filter, control = "-H -t")
}
Get or set the environment in which code chunks are evaluated.
knit_global(envir = NULL)
envir |
If |
A hook is a function of a pre-defined form (arguments) that takes values of
arguments and returns desired output. The object knit_hooks
is used to
access or set hooks in this package.
knit_hooks
An object of class list
of length 7.
Usage: https://yihui.org/knitr/objects/
Components in knit_hooks
: https://yihui.org/knitr/hooks/
knit_hooks$get("source")
#> function (x, options)
#> x
#> <bytecode: 0x55f86e923b30>
#> <environment: namespace:knitr>
knit_hooks$get("inline")
#> function (x)
#> {
#> if (is.numeric(x))
#> x = round_digits(x)
#> paste(as.character(x), collapse = ", ")
#> }
#> <bytecode: 0x55f86e9233c0>
#> <environment: namespace:knitr>
As an object is printed, knitr will collect metadata about it (if
available). After knitting is done, all the metadata is accessible via this
function. You can manually add metadata to the knitr session via
knit_meta_add()
.
knit_meta(class = NULL, clean = TRUE)
knit_meta_add(meta, label = "")
class |
Optionally return only metadata entries that inherit from the
specified class. The default, |
clean |
Whether to clean the collected metadata. By default, the
metadata stored in knitr is cleaned up once retrieved, because we may
not want the metadata to be passed to the next |
meta |
A metadata object to be added to the session. |
label |
A chunk label to indicate which chunk the metadata belongs to. |
knit_meta()
returns the matched metadata specified by
class
; knit_meta_add()
returns all current metadata.
This function reads the YAML front-matter section of a document and returns a
list of any parameters declared there. This function exists primarily to
support the parameterized reports feature of the rmarkdown package,
however is also used by the knitr purl
function to include
the default parameter values in the R code it emits.
knit_params(text, evaluate = TRUE)
text |
Character vector containing the document text. |
evaluate |
Boolean. If |
Parameters are included in YAML front matter using the params
key.
This key can have any number of subkeys each of which represents a
parameter. For example:
--- title: My Document output: html_document params: frequency: 10 show_details: true ---
Parameter values can be provided inline as illustrated above or can be
included in a value
sub-key. For example:
--- title: My Document output: html_document params: frequency: value: 10 ---
This second form is useful when you need to provide additional details
about the parameter (e.g. a label
field as describe above).
You can also use R code to yield the value of a parameter by prefacing the value
with !r
, for example:
--- title: My Document output: html_document params: start: !r Sys.Date() ---
List of objects of class knit_param
that correspond to the
parameters declared in the params
section of the YAML front matter.
These objects have the following fields:
name
The parameter name.
value
The default value for the parameter.
expr
The R expression (if any) that yielded the default value.
In addition, other fields included in the YAML may also be present
alongside the name, type, and value fields (e.g. a label
field
that provides front-ends with a human readable name for the parameter).
This function reads the YAML front-matter that has already been extracted from a document and returns a list of any parameters declared there.
knit_params_yaml(yaml, evaluate = TRUE)
yaml |
Character vector containing the YAML text. |
evaluate |
If |
List of objects of class knit_param
that correspond to the
parameters declared in the params
section of the YAML. See
knit_params
for a full description of these objects.
Patterns are regular expressions and will be used in functions like
base::grep()
to extract R code and chunk options. The object
knit_patterns
controls the patterns currently used; see the references
and examples for usage. All built-in patterns are available in the list
all_patterns.
knit_patterns
An object of class list
of length 7.
Usage: https://yihui.org/knitr/objects/
Components in knit_patterns
: https://yihui.org/knitr/patterns/
library(knitr)
opat = knit_patterns$get() # old pattern list (to restore later)
apats = all_patterns # a list of all built-in patterns
str(apats)
#> List of 8
#> $ rnw :List of 7
#> ..$ chunk.begin : chr "^\\s*<<(.*)>>=.*$"
#> ..$ chunk.end : chr "^\\s*@\\s*(%+.*|)$"
#> ..$ inline.code : chr "\\\\Sexpr\\{([^}]+)\\}"
#> ..$ inline.comment: chr "^\\s*%.*"
#> ..$ ref.chunk : chr "^\\s*<<(.+)>>\\s*$"
#> ..$ header.begin : chr "(^|\n)\\s*\\\\documentclass[^}]+\\}"
#> ..$ document.begin: chr "\\s*\\\\begin\\{document\\}"
#> $ brew :List of 1
#> ..$ inline.code: chr "<%[=]{0,1}\\s+([^%]+)\\s+[-]*%>"
#> $ tex :List of 8
#> ..$ chunk.begin : chr "^\\s*%+\\s*begin.rcode\\s*(.*)"
#> ..$ chunk.end : chr "^\\s*%+\\s*end.rcode"
#> ..$ chunk.code : chr "^\\s*%+"
#> ..$ ref.chunk : chr "^%+\\s*<<(.+)>>\\s*$"
#> ..$ inline.comment: chr "^\\s*%.*"
#> ..$ inline.code : chr "\\\\rinline\\{([^}]+)\\}"
#> ..$ header.begin : chr "(^|\n)\\s*\\\\documentclass[^}]+\\}"
#> ..$ document.begin: chr "\\s*\\\\begin\\{document\\}"
#> $ html :List of 5
#> ..$ chunk.begin : chr "^\\s*<!--\\s*begin.rcode\\s*(.*)"
#> ..$ chunk.end : chr "^\\s*end.rcode\\s*-->"
#> ..$ ref.chunk : chr "^\\s*<<(.+)>>\\s*$"
#> ..$ inline.code : chr "<!--\\s*rinline(.+?)-->"
#> ..$ header.begin: chr "\\s*<head>"
#> $ md :List of 4
#> ..$ chunk.begin: chr "^[\t >]*```+\\s*\\{([a-zA-Z0-9_]+( *[ ,].*)?)\\}\\s*$"
#> ..$ chunk.end : chr "^[\t >]*```+\\s*$"
#> ..$ ref.chunk : chr "^\\s*<<(.+)>>\\s*$"
#> ..$ inline.code: chr "(?<!(^``))(?<!(\n``))`r[ #]([^`]+)\\s*`"
#> $ rst :List of 5
#> ..$ chunk.begin: chr "^\\s*[.][.]\\s+\\{r(.*)\\}\\s*$"
#> ..$ chunk.end : chr "^\\s*[.][.]\\s+[.][.]\\s*$"
#> ..$ chunk.code : chr "^\\s*[.][.]"
#> ..$ ref.chunk : chr "^\\.*\\s*<<(.+)>>\\s*$"
#> ..$ inline.code: chr ":r:`([^`]+)`"
#> $ asciidoc:List of 6
#> ..$ chunk.begin : chr "^//\\s*begin[.]rcode(.*)$"
#> ..$ chunk.end : chr "^//\\s*end[.]rcode\\s*$"
#> ..$ chunk.code : chr "^//+"
#> ..$ ref.chunk : chr "^\\s*<<(.+)>>\\s*$"
#> ..$ inline.code : chr "`r +([^`]+)\\s*`|[+]r +([^+]+)\\s*[+]"
#> ..$ inline.comment: chr "^//.*"
#> $ textile :List of 5
#> ..$ chunk.begin : chr "^###[.]\\s+begin[.]rcode(.*)$"
#> ..$ chunk.end : chr "^###[.]\\s+end[.]rcode\\s*$"
#> ..$ ref.chunk : chr "^\\s*<<(.+)>>\\s*$"
#> ..$ inline.code : chr "@r +([^@]+)\\s*@"
#> ..$ inline.comment: chr "^###[.].*"
knit_patterns$set(apats[["rnw"]]) # set pattern list from apats
knit_patterns$get(c("chunk.begin", "chunk.end", "inline.code"))
#> $chunk.begin
#> [1] "^\\s*<<(.*)>>=.*$"
#>
#> $chunk.end
#> [1] "^\\s*@\\s*(%+.*|)$"
#>
#> $inline.code
#> [1] "\\\\Sexpr\\{([^}]+)\\}"
# a customized pattern list; has to empty the original patterns first!
knit_patterns$restore()
# we may want to use this in an HTML document
knit_patterns$set(list(chunk.begin = "<!--helloR\\s+(.*)", chunk.end = "^byeR-->"))
str(knit_patterns$get())
#> List of 9
#> $ chunk.begin : chr "<!--helloR\\s+(.*)"
#> $ chunk.end : chr "^byeR-->"
#> $ chunk.code : NULL
#> $ inline.code : NULL
#> $ global.options: NULL
#> $ input.doc : NULL
#> $ ref.chunk : NULL
#> $ header.begin : NULL
#> $ document.begin: NULL
knit_patterns$set(opat) # put the old patterns back
The S3 generic function knit_print
is the default printing function in
knitr. The chunk option render
uses this function by default.
The main purpose of this S3 generic function is to customize printing of R
objects in code chunks. We can fall back to the normal printing behavior by
setting the chunk option render = normal_print
.
knit_print(x, ...)
normal_print(x, ...)
x |
An R object to be printed |
... |
Additional arguments passed to the S3 method. Currently ignored,
except two optional arguments |
Users can write custom methods based on this generic function. For example,
if we want to print all data frames as tables in the output, we can define a
method knit_print.data.frame
that turns a data.frame into a table (the
implementation may use other R packages or functions, e.g. xtable or
kable()
).
The value returned from the print method should be a character vector
or can be converted to a character value. You can wrap the value in
asis_output()
so that knitr writes the character value
as is in the output.
It is recommended to leave a ...
argument in your method, to
allow future changes of the knit_print()
API without breaking your
method.
See vignette('knit_print', package = 'knitr')
.
library(knitr)
# write tables for data frames
knit_print.data.frame = function(x, ...) {
res = paste(c("", "", kable(x, output = FALSE)), collapse = "\n")
asis_output(res)
}
# register the method
registerS3method("knit_print", "data.frame", knit_print.data.frame)
# after you define and register the above method, data frames will be printed
# as tables in knitr, which is different with the default print() behavior
Run examples in a package and insert output into the examples code;
knit_rd_all()
is a wrapper around knit_rd()
to build static
HTML help pages for all packages under the ‘html’ directory of them.
knit_rd(pkg, links = tools::findHTMLlinks(), frame = TRUE)
knit_rd_all()
pkg |
Package name. |
links |
A character vector of links to be passed to
|
frame |
Boolean: whether to put a navigation frame on the left of the index page. |
All HTML pages corresponding to topics in the package are written under the current working directory. An ‘index.html’ is also written as a table of content.
Ideally the html pages should be put under the ‘html’ directory of
an installed package which can be found via system.file('html',
package = 'your_package_name')
, otherwise some links may not work (e.g.
the link to the DESCRITION file).
library(knitr)
knit_rd("maps")
knit_rd("rpart")
setwd(system.file("html", package = "ggplot2"))
knit_rd("ggplot2") # time-consuming!
knit_rd_all() # this may take really long time if you have many packages installed
This object can be used to set or get themes in knitr for syntax highlighting.
knit_theme
An object of class list
of length 2.
We can use knit_theme$set(theme)
to set the theme, and
knit_theme$get(theme)
to get a theme. The theme
is a character
string for both methods (either the name of the theme, or the path to the CSS
file of a theme), and for the set()
method, it can also be a list
returned by the get()
method. See examples below.
The syntax highlighting here only applies to ‘.Rnw’ (LaTeX) and ‘.Rhtml’ (HTML) documents, and it does not work for other types of documents, such as ‘.Rmd’ (R Markdown, which has its own syntax highlighting themes; see https://rmarkdown.rstudio.com).
Ramnath Vaidyanathan and Yihui Xie
For a preview of all themes, see https://gist.github.com/yihui/3422133.
opts_knit$set(out.format = "latex")
knit_theme$set("edit-vim")
knit_theme$get() # names of all available themes
#> [1] "acid" "aiseered" "andes" "anotherdark"
#> [5] "autumn" "baycomb" "bclear" "biogoo"
#> [9] "bipolar" "blacknblue" "bluegreen" "breeze"
#> [13] "bright" "camo" "candy" "clarity"
#> [17] "dante" "darkblue" "darkbone" "darkness"
#> [21] "darkslategray" "darkspectrum" "default" "denim"
#> [25] "dusk" "earendel" "easter" "edit-anjuta"
#> [29] "edit-eclipse" "edit-emacs" "edit-flashdevelop" "edit-gedit"
#> [33] "edit-jedit" "edit-kwrite" "edit-matlab" "edit-msvs2008"
#> [37] "edit-nedit" "edit-vim-dark" "edit-vim" "edit-xcode"
#> [41] "ekvoli" "fine_blue" "freya" "fruit"
#> [45] "golden" "greenlcd" "greyscale0" "greyscale1"
#> [49] "greyscale2" "kellys" "leo" "lucretia"
#> [53] "manxome" "maroloccio" "matrix" "moe"
#> [57] "molokai" "moria" "navajo-night" "navy"
#> [61] "neon" "night" "nightshimmer" "nuvola"
#> [65] "olive" "orion" "oxygenated" "pablo"
#> [69] "peaksea" "print" "rand01" "rdark"
#> [73] "relaxedgreen" "rootwater" "seashell" "solarized-dark"
#> [77] "solarized-light" "tabula" "tcsoft" "vampire"
#> [81] "whitengrey" "xoria256" "zellner" "zenburn"
#> [85] "zmrok"
thm = knit_theme$get("acid") # parse the theme to a list
knit_theme$set(thm)
opts_knit$set(out.format = NULL) # restore option
Check the modification time of an input file continously in an infinite loop. Whenever the time indicates the file has been modified, call a function to recompile the input file.
knit_watch(input, compile = knit, interval = 1, ...)
input |
An input file path, or a character vector of mutiple input file paths. |
compile |
A function to compile the |
interval |
A time interval to pause in each cycle of the infinite loop. |
... |
Other arguments to be passed to the |
This is actually a general function not necessarily restricted to
applications in knitr. You may specify any compile
function to
process the input
file. To stop the infinite loop, press the
‘Escape’ key or ‘Ctrl + C’ (depending on your editing environment
and operating system).
# knit_watch('foo.Rnw', knit2pdf)
# knit_watch('foo.Rmd', rmarkdown::render)
If a code chunk has turned on the chunk option cache = TRUE
, a cache
database will be established after the document is compiled. You can use this
function to manually load the database anywhere in the document (even before
the code chunk). This makes it possible to use objects created later in the
document earlier, e.g. in an inline R expression before the cached code
chunk, which is normally not possible because knitr compiles the
document in a linear fashion, and objects created later cannot be used before
they are created.
load_cache(
label,
object,
notfound = "NOT AVAILABLE",
path = opts_chunk$get("cache.path"),
dir = opts_knit$get("output.dir"),
envir = NULL,
lazy = TRUE
)
label |
The chunk label of the code chunk that has a cache database. |
object |
The name of the object to be fetched from the database. If it
is missing, |
notfound |
A value to use when the |
path |
Path of the cache database (normally set in the global chunk
option |
dir |
Path to use as the working directory. Defaults to the output
directory if run inside a knitr context and to the current working
directory otherwise. Any relative |
envir |
Environment to use for cache loading, into which all objects in
the cache for the specified chunk (not just that in |
lazy |
Whether to |
Invisible NULL
when object
is not specified (the cache
database will be loaded as a side effect), otherwise the value of the
object if found.
Apparently this function loads the value of the object from the previous run of the document, which may be problematic when the value of the object becomes different the next time the document is compiled. Normally you must compile the document twice to make sure the cache database is created, and the object can be read from it. Please use this function with caution.
See the example #114 at https://github.com/yihui/knitr-examples.
Options for R code chunks. When running R code, the object opts_chunk
(default options) is not modified by chunk headers (local chunk options are
merged with default options), whereas opts_current
(current options)
changes with different chunk headers and it always reflects the options for
the current chunk.
opts_chunk
opts_current
An object of class list
of length 7.
An object of class list
of length 7.
Normally we set up the global options once in the first code chunk in a
document using opts_chunk$set()
, so that all latter chunks will
use these options. Note the global options set in one chunk will not affect
the options in this chunk itself, and that is why we often need to set global
options in a separate chunk.
See str(knitr::opts_chunk$get())
for a list of default chunk options.
opts_current
should be treated as read-only and you are supposed
to only query its values via opts_current$get()
. Calling
opts_current$set()
will throw an error.
Usage: https://yihui.org/knitr/objects/
A list of available options: https://yihui.org/knitr/options/#chunk-options
opts_chunk$get("prompt")
#> [1] FALSE
opts_chunk$get("fig.keep")
#> [1] "high"
Like knit_hooks
, this object can be used to set hook functions
to manipulate chunk options.
opts_hooks
An object of class list
of length 7.
For every code chunk, if the chunk option named, say, FOO
, is not
NULL
, and a hook function with the same name has been set via
opts_hooks$set(FOO = function(options) { options })
(you can manipuate
the options
argument in the function and return it), the hook function
will be called to update the chunk options.
https://yihui.org/knitr/hooks/
# make sure the figure width is no smaller than fig.height
opts_hooks$set(fig.width = function(options) {
if (options$fig.width < options$fig.height) {
options$fig.width = options$fig.height
}
options
})
# remove all hooks
opts_hooks$restore()
Options including whether to use a progress bar when knitting a document, and the base directory of images, etc.
opts_knit
An object of class list
of length 7.
Besides the standard usage (opts_knit$set()
), we can also set package
options prior to loading knitr
or calling knit()
using
options()
in base R. A global option knitr.package.foo
in options()
will be set as an option foo
in opts_knit
,
i.e. global options in base R with the prefix knitr.package.
correspond to options in opts_knit
. This can be useful to set package
options in ‘~/.Rprofile’ without loading knitr.
See str(knitr::opts_knit$get())
for a list of default package options.
Usage: https://yihui.org/knitr/objects/
A list of available options: https://yihui.org/knitr/options/#package-options
opts_knit$get("verbose")
#> [1] FALSE
opts_knit$set(verbose = TRUE) # change it
if (interactive()) {
# for unnamed chunks, use 'fig' as the figure prefix
opts_knit$set(unnamed.chunk.label = "fig")
knit("001-minimal.Rmd") # from https://github.com/yihui/knitr-examples
}
Creates a template binding a label to a set of chunk options. Every chunk that references the template label will have the specified set of options applied to it.
opts_template
An object of class list
of length 7.
opts_template$set(myfigures = list(fig.height = 4, fig.width = 4))
# later you can reuse these chunk options by 'opts.label', e.g.
# <<foo, opts.label='myfigures'>>=
# the above is equivalent to <<foo, fig.height=4, fig.width=4>>=
The render_*()
functions set built-in output hooks for LaTeX, HTML,
Markdown, reStructuredText, AsciiDoc, and Textile. The hooks_*()
functions return a list of the output hooks for the corresponding format.
render_html()
hooks_html()
render_asciidoc()
hooks_asciidoc()
render_latex()
hooks_latex()
render_sweave()
hooks_sweave(envirs = c("Sinput", "Soutput", "Schunk"))
render_listings()
hooks_listings(envirs = c("Sinput", "Soutput", "Schunk"))
render_markdown(strict = FALSE, fence_char = "`")
hooks_markdown(strict = FALSE, fence_char = "`")
render_jekyll(highlight = c("pygments", "prettify", "none"), extra = "")
hooks_jekyll(highlight = c("pygments", "prettify", "none"), extra = "")
render_rst(strict = FALSE)
hooks_rst(strict = FALSE)
render_textile()
hooks_textile()
envirs |
Names of LaTeX environments for code input, output, and chunk. |
strict |
Boolean; whether to use strict markdown or reST syntax. For markdown, if
|
fence_char |
A single character to be used in the code blocks fence. This can be e.g. a backtick or a tilde, depending on your Markdown rendering engine. |
highlight |
Which code highlighting engine to use: if |
extra |
Extra tags for the highlighting engine. For |
There are three variants of Markdown documents: ordinary Markdown
(render_markdown(strict = TRUE)
, which calls
hooks_markdown(strict = TRUE)
), extended Markdown (e.g., GitHub
Flavored Markdown and Pandoc; render_markdown(strict = FALSE)
, which
calls hooks_markdown(strict = FALSE)
), and Jekyll (a blogging system
on GitHub; render_jekyll()
, which calls hooks_jekyll()
).
For LaTeX output, there are three variants: knitr's default style
(render_latex()
, which calls hooks_latex()
and uses the LaTeX
framed package), Sweave style (render_sweave()
, which calls
hooks_sweave()
and uses ‘Sweave.sty’), and listings style
(render_listings()
, which calls hooks_listings()
and uses LaTeX
listings package).
Default HTML output hooks are set by render_html()
(which calls
hooks_html()
); render_rst()
(which calls hooks_rst()
) is
for reStructuredText; render_textile()
(which calls
hooks_textile()
) is for Textile, and render_asciidoc()
(which
calls hooks_asciidoc()
) is AsciiDoc.
The render_*()
functions can be used before knit()
or in the
first chunk of the input document (ideally this chunk has options
include = FALSE
and cache = FALSE
) so that all the following
chunks will be formatted as expected.
You can also use knit_hooks
to set the format's hooks with the
hooks_*()
functions; see references for more info on further
customizing output hooks.
NULL
for render_*
functions; corresponding hooks are
set as a side effect. A list of output hooks for hooks_*()
functions.
See output hooks in https://yihui.org/knitr/hooks/, and some examples in https://bookdown.org/yihui/rmarkdown-cookbook/output-hooks.html
Jekyll and Liquid: https://github.com/jekyll/jekyll/wiki/Liquid-Extensions; prettify.js: https://code.google.com/archive/p/google-code-prettify
# below is pretty much what knitr::render_markdown() does:
knitr::knit_hooks$set(knitr::hooks_markdown())
# you can retrieve a subset of the hooks and set them, e.g.,
knitr::knit_hooks$set(knitr::hooks_markdown()["source"])
knitr::knit_hooks$restore()
The function is_latex_output()
returns TRUE
when the output
format is LaTeX; it works for both ‘.Rnw’ and R Markdown documents (for
the latter, the two Pandoc formats latex
and beamer
are
considered LaTeX output). The function is_html_output()
only works for
R Markdown documents and will test for several Pandoc HTML based output
formats (by default, these formats are considered as HTML formats:
c('markdown', 'epub', 'epub2', 'html', 'html4', 'html5', 'revealjs', 's5',
'slideous', 'slidy', 'gfm')
).
is_latex_output()
is_html_output(fmt = pandoc_to(), excludes = NULL)
pandoc_to(fmt, exact = FALSE)
pandoc_from(exact = FALSE)
fmt |
A character vector of output formats to be checked against. If not
provided, |
excludes |
A character vector of output formats that should not be considered as HTML format. Options are: markdown, epub, epub2, html, html4, html5, revealjs, s5, slideous, slidy, and gfm. |
exact |
Whether to return or use the exact format name. If not, Pandoc extensions will be removed from the format name, e.g., ‘latex-smart’ will be treated as ‘latex’. |
The function pandoc_to()
returns the Pandoc output format, and
pandoc_from()
returns Pandoc input format. pandoc_to(fmt)
allows to check the current output format against a set of format names. Both
are to be used with R Markdown documents.
These functions may be useful for conditional output that depends on the
output format. For example, you may write out a LaTeX table in an R Markdown
document when the output format is LaTeX, and an HTML or Markdown table when
the output format is HTML. Use pandoc_to(fmt)
to test a more specific
Pandoc format.
Internally, the Pandoc output format of the current R Markdown document is
stored in knitr::opts_knit$get('rmarkdown.pandoc.to')
, and the
Pandoc input format in
knitr::opts_knit$get('rmarkdown.pandoc.from')
See available Pandoc formats, in Pandoc's Manual
# check for output formats type
knitr::is_latex_output()
#> [1] FALSE
knitr::is_html_output()
#> [1] FALSE
knitr::is_html_output(excludes = c("markdown", "epub"))
#> [1] FALSE
# Get current formats
knitr::pandoc_from()
#> [1] "markdown"
knitr::pandoc_to()
#> NULL
# Test if current output format is 'docx'
knitr::pandoc_to("docx")
#> [1] FALSE
This function calls Pandoc to convert documents to other formats such as HTML, LaTeX/PDF and Word, etc, (optionally) based on a configuration file or in-file configurations which specify the options to use for Pandoc.
pandoc(input, format, config = getOption("config.pandoc"), ext = NA)
input |
A character vector of Markdown filenames (must be encoded in UTF-8). |
format |
Name of the output format (see References). This can be a
character vector of multiple formats; by default, it is obtained from the
|
config |
Path to the Pandoc configuration file. If missing, it is
assumed to be a file with the same base name as the |
ext |
Filename extensions. By default, the extension is inferred from
the |
There are two ways to input the Pandoc configurations – through a config
file, or embed the configurations in the input file as special comments
between <!--pandoc
and -->
.
The configuration file is a DCF file (see read.dcf
). This file
must contain a field named t
which means the output format. The
configurations are written in the form of tag:value
and passed to
Pandoc (if no value is needed, just leave it empty, e.g. the option
standalone
or s
for short). If there are multiple output
formats, write each format and relevant configurations in a block, and
separate blocks with blank lines.
If there are multiple records of the t
field in the configuration, the
input markdown file will be converted to all these formats by default, unless
the format
argument is specified as one single format.
The output filename(s) (or an error if the conversion failed).
Pandoc: https://pandoc.org; Examples and rules of the configurations: https://yihui.org/knitr/demo/pandoc/
Also see R Markdown (v2) at https://rmarkdown.rstudio.com. The rmarkdown package has several convenience functions and templates that make it very easy to use Pandoc. The RStudio IDE also has comprehensive support for it, so I'd recommend users who are not familiar with command-line tools to use the rmarkdown package instead.
system("pandoc -h") # see possible output formats
This is a wrapper function calling xfun::divide_chunk()
under the hood.
partition_chunk(engine, code)
These are convenience functions to set pre-defined pattern lists (the syntax
to read input documents). The function names are built from corresponding
file extensions, e.g. pat_rnw()
can set the Sweave syntax to read Rnw
documents.
pat_rnw()
pat_brew()
pat_tex()
pat_html()
pat_md()
pat_rst()
pat_asciidoc()
pat_textile()
The patterns object knit_patterns
is modified as a side
effect.
# see how knit_patterns is modified
knit_patterns$get()
#> $chunk.begin
#> NULL
#>
#> $chunk.end
#> NULL
#>
#> $chunk.code
#> NULL
#>
#> $inline.code
#> NULL
#>
#> $global.options
#> NULL
#>
#> $input.doc
#> NULL
#>
#> $ref.chunk
#> NULL
#>
#> $header.begin
#> NULL
#>
#> $document.begin
#> NULL
pat_rnw()
knit_patterns$get()
#> $chunk.begin
#> [1] "^\\s*<<(.*)>>=.*$"
#>
#> $chunk.end
#> [1] "^\\s*@\\s*(%+.*|)$"
#>
#> $inline.code
#> [1] "\\\\Sexpr\\{([^}]+)\\}"
#>
#> $inline.comment
#> [1] "^\\s*%.*"
#>
#> $ref.chunk
#> [1] "^\\s*<<(.+)>>\\s*$"
#>
#> $header.begin
#> [1] "(^|\n)\\s*\\\\documentclass[^}]+\\}"
#>
#> $document.begin
#> [1] "\\s*\\\\begin\\{document\\}"
knit_patterns$restore() # empty the list
The program pdfcrop
(often shipped with a LaTeX distribution) is
executed on a PDF plot file, and
magick::image_trim()
is executed for other
types of plot files.
plot_crop(x, quiet = TRUE)
x |
Filename of the plot. |
quiet |
Whether to suppress standard output from the command. |
The program pdfcrop
can crop the extra white margins when the plot
format is PDF, to make better use of the space in the output document,
otherwise we often have to struggle with graphics::par()
to set
appropriate margins. Note pdfcrop
often comes with a LaTeX
distribution such as TinyTeX, MiKTeX, or TeX Live, and you may not need to
install it separately (use Sys.which('pdfcrop')
to check it; if it not
empty, you are able to use it). Note that pdfcrop
depends on
GhostScript. You can check if GhostScript is installed via
tools::find_gs_cmd()
.
The original filename.
PDFCrop: https://www.ctan.org/pkg/pdfcrop. If you use
TinyTeX, you may install pdfcrop
with
tinytex::tlmgr_install('pdfcrop')
.
This expression returns .Random.seed
when eval(rand_seed)
and
NULL
otherwise.
rand_seed
It is designed to work with opts_chunk$set(cache.extra = rand_seed)
for reproducibility of chunks that involve with random number generation. See
references.
https://yihui.org/knitr/demo/cache/
eval(rand_seed)
#> [1] 10403 56 -1064009061 -514322183 169112136 335961462 -580236111
#> [8] -1557946141 1336410034 735100932 -944245945 -1477826019 -534658924 -1131925446
#> [15] -1160023419 -252562593 844450790 1331349104 1138534803 -1106309583 1447470304
#> [22] 1120146814 1996163081 -1176770501 -1326696950 -917674516 1035151983 -682269275
#> [29] -1885121188 364103986 681777197 -220825881 -874226674 163497448 943992811
#> [36] -306081655 1158382616 816206662 -42708575 1852702771 -969159262 -345081708
#> [43] -71782633 1141049613 -1274339292 2091114506 -719125131 1703609551 549136342
#> [50] 535062400 -1816478781 472837473 1689793488 -1675197650 -265101607 -268391189
#> [57] -437998246 313868060 1070660127 -1304393099 600721164 1185733346 -1269850179
#> [64] -918607817 -488135970 1948532248 88981883 -383330023 1744004520 413419862
#> [71] 294771153 1516820867 14141458 -1584690268 -578053273 1649655997 -2099455948
#> [78] -519316582 -70068251 -93944961 1049019142 731376784 -263873229 -1686832431
#> [85] -334913408 -81266338 -736399703 446871899 1205080938 -1729340916 204835407
#> [92] -2118637819 675278780 1863568018 -1457565299 -1399309881 -432239954 -1329380600
#> [99] -579419893 -1238384663 -971790152 -1715462298 1164356609 219380371 -796422846
#> [106] -1702919436 -1083134217 -788549907 459233668 416323498 435309845 -1922357329
#> [113] -1961474122 -796156448 -1490438877 558017089 925041968 -900440242 -1825405511
#> [120] 1987270603 -1592382342 -289706628 -574716481 -417062251 -425467732 -1289229694
#> [127] 1559716445 -85363369 1636202558 -1730225032 -750278821 -572939591 -1221615864
#> [134] 52835766 1263209201 163839267 267908978 1333065156 -260330105 -1350541475
#> [141] -1970982572 -314694790 -2129497403 1190212639 -1068981338 82949424 -132335661
#> [148] 1600886257 1159578400 307146174 1472693705 -349259397 -987676854 2022637484
#> [155] -375748945 -944245659 898667548 -653444494 -1193214739 -1906506457 1631375694
#> [162] -3341912 1592407467 1446825673 1171617496 1647909766 1156689505 1854322675
#> [169] -118232478 -155734828 -1677816361 412231629 686969700 -1030719670 -771207499
#> [176] -1083185649 10671894 -806407744 -1006497405 972359585 -1716918384 -553878418
#> [183] -382588391 -78081365 -2143410534 877326940 499052383 -1262436043 -2112642868
#> [190] -359962078 592282749 -8938121 -1944907106 -1050230440 871061691 1141581401
#> [197] 1190958568 1460113430 -33236079 -112942013 2015828818 -238813212 -319955417
#> [204] -1789970819 -1267832972 -527377574 1394126245 1006012863 82027078 -808111920
#> [211] 293980915 -288625647 -1975559616 913260062 31774953 299874843 -418616790
#> [218] 1077247308 -1513480433 651854405 2078745596 853858898 303368141 1447719303
#> [225] 1096696942 1211980872 1149879883 1639627689 -1882836232 1369641120 -748610686
#> [232] -73223448 1756386028 676179004 -1167482254 -765909904 204539428 843318328
#> [239] -392812518 222792400 -423877572 1466799252 -1924117374 -265918528 716446012
#> [246] -96488816 -29336542 -1752390648 634747020 -158340068 -1267513710 109048960
#> [253] -2949100 -918117080 -1194701254 904389840 1962017900 -136932684 -95041518
#> [260] 332117984 250204108 -149525024 -633590238 -1417123544 485011724 982390332
#> [267] 2014241010 1754118896 -266665148 1386064472 408957498 1840031472 347847868
#> [274] 952552980 146292930 -1455640480 820514172 871267536 79903778 -421299544
#> [281] -1011519604 270588348 -1116425166 2030040896 1662105780 -980131000 -102679878
#> [288] -1920798960 1226938604 1338094676 -539121902 1480168352 752402380 -891630752
#> [295] -602943294 -1882991064 1573012908 -2034073796 1865092978 -1443814608 -364740060
#> [302] 1786458168 1942473946 2135048592 -1260509444 897220500 -549084350 -2121360896
#> [309] 266543676 133764688 -1838411102 3402568 -796050932 1810386140 1244865106
#> [316] -1705166720 -1827873964 -7589400 -1184109830 -1608009904 1100727340 1248236916
#> [323] -276935022 902158944 -1662938484 712444768 -1515629854 893089960 -1738043188
#> [330] -1186090500 929931186 1743656432 -1590170172 867067736 -895100038 -441958992
#> [337] 1112039868 -2014785452 -1911213118 1433539360 -828401732 1523577424 1289633250
#> [344] -7339672 -1168790196 920703228 150889202 1075715840 -872071564 185716744
#> [351] -760897094 270876624 -1283859988 -2105141356 -898497838 -1315193248 -1955912372
#> [358] 903554336 -12924286 176642536 1939431404 -28637636 962459250 -695440528
#> [365] 757815588 1714934328 -1484641894 323336656 -290232900 325417108 715199618
#> [372] 1999570368 757574460 521972880 1445940002 -1772136952 889967884 -54819428
#> [379] -1344512494 797256576 824640276 1799258408 -1572789190 -754938928 -2076800404
#> [386] 20169268 -1974433134 -957799072 -1486030516 -338073632 255243682 -842431064
#> [393] 1516275340 -1807786564 1185676914 1669018608 -1714590140 21569624 155854906
#> [400] -483282832 -246507460 1076117780 -154492222 -83237152 -1001899908 1157101264
#> [407] 2099820962 1721440296 -52614388 767453628 -334093518 1133996736 1044745268
#> [414] -1836196152 -524323654 118535824 -641208596 -2120746412 -1807801710 268364064
#> [421] -122416692 -132160800 1438843074 -769397720 1126545324 605301436 -1896072206
#> [428] -7637456 -154775644 740560312 -1066895526 42201232 -1003934852 -1070784236
#> [435] 1887373634 -464703232 -1297613380 -565870256 -1040656094 1239407176 1898885132
#> [442] -383007140 2129865170 603477504 594519380 940764392 1471328506 -1356020016
#> [449] 1951951660 -1601818380 1326676370 -2120254112 1678367756 -1923916576 793956962
#> [456] 831095976 1147542218 1892881343 -2140225783 -1119590370 723638732 1453765533
#> [463] -2023412185 -2100820912 386813166 1520150939 1699700733 1755736810 944307592
#> [470] 71265073 -852024413 -132947036 -1452429742 665849255 -1684788751 -1073373898
#> [477] -59251244 127732581 1417917295 759172520 -117533946 1085490739 850234517
#> [484] -1411599118 -1385851584 1675999913 737997595 -2141420308 -738711302 1918712111
#> [491] -42205895 -700223666 261424540 -1689549043 1408225655 299844992 1210471390
#> [498] -321905493 1988356013 -1590354918 2121011928 -244982975 -1602266125 -535976428
#> [505] 722567074 -1491140425 -1786914175 1592560262 1014221508 1837607925 1299710559
#> [512] -2140547912 -1577094762 1282993059 -1180037275 -1463843198 704369648 1031357849
#> [519] 1136208779 -230119812 -174908246 15101663 -1099373463 -1031831938 -1530923412
#> [526] -235685187 -1088993401 488162160 1782592014 -1705181381 407536669 340643018
#> [533] 1788172264 1715512529 -719736637 -1038633020 118314098 1718750535 830021905
#> [540] 101057686 54508020 -1296970875 -519437617 1729814472 -1702005146 441833619
#> [547] -987248651 -819666478 1875905056 786310153 1498749243 1222257804 318032154
#> [554] 142413711 261460185 1226964846 -1095604484 -1834023827 2063458327 979433952
#> [561] 1432159678 2088536971 -1240900595 -793899974 -885613448 1930475553 1352995539
#> [568] 229622260 319957634 -693254377 -382136863 1691869990 554860068 -1091032875
#> [575] 1822951551 831311128 1152844854 506464963 888678149 1918229154 -1533691760
#> [582] 1070655545 -190261013 1049278940 261300234 1059798783 752742217 -501578530
#> [589] -431555956 -705884579 -4492185 -1729300080 270977454 992291931 2084613181
#> [596] 145179306 100745032 -1285155983 1591768291 -1060078620 393964306 -2003196185
#> [603] -1390792527 -1887386890 -1145780972 416381477 410363695 -1487193880 2109290950
#> [610] 1397274739 -1748348203 558117042 1796101248 1509222505 -1545763621 1735608364
#> [617] -1348732870 -1116989713 -1568466567 -957413874 -282286116 -759885747 534827959
#> [624] 330886464 1804143646 -267855448
rnorm(1) # .Random.seed is created (or modified)
#> [1] -0.7918675
eval(rand_seed)
#> [1] 10403 58 -1064009061 -514322183 169112136 335961462 -580236111
#> [8] -1557946141 1336410034 735100932 -944245945 -1477826019 -534658924 -1131925446
#> [15] -1160023419 -252562593 844450790 1331349104 1138534803 -1106309583 1447470304
#> [22] 1120146814 1996163081 -1176770501 -1326696950 -917674516 1035151983 -682269275
#> [29] -1885121188 364103986 681777197 -220825881 -874226674 163497448 943992811
#> [36] -306081655 1158382616 816206662 -42708575 1852702771 -969159262 -345081708
#> [43] -71782633 1141049613 -1274339292 2091114506 -719125131 1703609551 549136342
#> [50] 535062400 -1816478781 472837473 1689793488 -1675197650 -265101607 -268391189
#> [57] -437998246 313868060 1070660127 -1304393099 600721164 1185733346 -1269850179
#> [64] -918607817 -488135970 1948532248 88981883 -383330023 1744004520 413419862
#> [71] 294771153 1516820867 14141458 -1584690268 -578053273 1649655997 -2099455948
#> [78] -519316582 -70068251 -93944961 1049019142 731376784 -263873229 -1686832431
#> [85] -334913408 -81266338 -736399703 446871899 1205080938 -1729340916 204835407
#> [92] -2118637819 675278780 1863568018 -1457565299 -1399309881 -432239954 -1329380600
#> [99] -579419893 -1238384663 -971790152 -1715462298 1164356609 219380371 -796422846
#> [106] -1702919436 -1083134217 -788549907 459233668 416323498 435309845 -1922357329
#> [113] -1961474122 -796156448 -1490438877 558017089 925041968 -900440242 -1825405511
#> [120] 1987270603 -1592382342 -289706628 -574716481 -417062251 -425467732 -1289229694
#> [127] 1559716445 -85363369 1636202558 -1730225032 -750278821 -572939591 -1221615864
#> [134] 52835766 1263209201 163839267 267908978 1333065156 -260330105 -1350541475
#> [141] -1970982572 -314694790 -2129497403 1190212639 -1068981338 82949424 -132335661
#> [148] 1600886257 1159578400 307146174 1472693705 -349259397 -987676854 2022637484
#> [155] -375748945 -944245659 898667548 -653444494 -1193214739 -1906506457 1631375694
#> [162] -3341912 1592407467 1446825673 1171617496 1647909766 1156689505 1854322675
#> [169] -118232478 -155734828 -1677816361 412231629 686969700 -1030719670 -771207499
#> [176] -1083185649 10671894 -806407744 -1006497405 972359585 -1716918384 -553878418
#> [183] -382588391 -78081365 -2143410534 877326940 499052383 -1262436043 -2112642868
#> [190] -359962078 592282749 -8938121 -1944907106 -1050230440 871061691 1141581401
#> [197] 1190958568 1460113430 -33236079 -112942013 2015828818 -238813212 -319955417
#> [204] -1789970819 -1267832972 -527377574 1394126245 1006012863 82027078 -808111920
#> [211] 293980915 -288625647 -1975559616 913260062 31774953 299874843 -418616790
#> [218] 1077247308 -1513480433 651854405 2078745596 853858898 303368141 1447719303
#> [225] 1096696942 1211980872 1149879883 1639627689 -1882836232 1369641120 -748610686
#> [232] -73223448 1756386028 676179004 -1167482254 -765909904 204539428 843318328
#> [239] -392812518 222792400 -423877572 1466799252 -1924117374 -265918528 716446012
#> [246] -96488816 -29336542 -1752390648 634747020 -158340068 -1267513710 109048960
#> [253] -2949100 -918117080 -1194701254 904389840 1962017900 -136932684 -95041518
#> [260] 332117984 250204108 -149525024 -633590238 -1417123544 485011724 982390332
#> [267] 2014241010 1754118896 -266665148 1386064472 408957498 1840031472 347847868
#> [274] 952552980 146292930 -1455640480 820514172 871267536 79903778 -421299544
#> [281] -1011519604 270588348 -1116425166 2030040896 1662105780 -980131000 -102679878
#> [288] -1920798960 1226938604 1338094676 -539121902 1480168352 752402380 -891630752
#> [295] -602943294 -1882991064 1573012908 -2034073796 1865092978 -1443814608 -364740060
#> [302] 1786458168 1942473946 2135048592 -1260509444 897220500 -549084350 -2121360896
#> [309] 266543676 133764688 -1838411102 3402568 -796050932 1810386140 1244865106
#> [316] -1705166720 -1827873964 -7589400 -1184109830 -1608009904 1100727340 1248236916
#> [323] -276935022 902158944 -1662938484 712444768 -1515629854 893089960 -1738043188
#> [330] -1186090500 929931186 1743656432 -1590170172 867067736 -895100038 -441958992
#> [337] 1112039868 -2014785452 -1911213118 1433539360 -828401732 1523577424 1289633250
#> [344] -7339672 -1168790196 920703228 150889202 1075715840 -872071564 185716744
#> [351] -760897094 270876624 -1283859988 -2105141356 -898497838 -1315193248 -1955912372
#> [358] 903554336 -12924286 176642536 1939431404 -28637636 962459250 -695440528
#> [365] 757815588 1714934328 -1484641894 323336656 -290232900 325417108 715199618
#> [372] 1999570368 757574460 521972880 1445940002 -1772136952 889967884 -54819428
#> [379] -1344512494 797256576 824640276 1799258408 -1572789190 -754938928 -2076800404
#> [386] 20169268 -1974433134 -957799072 -1486030516 -338073632 255243682 -842431064
#> [393] 1516275340 -1807786564 1185676914 1669018608 -1714590140 21569624 155854906
#> [400] -483282832 -246507460 1076117780 -154492222 -83237152 -1001899908 1157101264
#> [407] 2099820962 1721440296 -52614388 767453628 -334093518 1133996736 1044745268
#> [414] -1836196152 -524323654 118535824 -641208596 -2120746412 -1807801710 268364064
#> [421] -122416692 -132160800 1438843074 -769397720 1126545324 605301436 -1896072206
#> [428] -7637456 -154775644 740560312 -1066895526 42201232 -1003934852 -1070784236
#> [435] 1887373634 -464703232 -1297613380 -565870256 -1040656094 1239407176 1898885132
#> [442] -383007140 2129865170 603477504 594519380 940764392 1471328506 -1356020016
#> [449] 1951951660 -1601818380 1326676370 -2120254112 1678367756 -1923916576 793956962
#> [456] 831095976 1147542218 1892881343 -2140225783 -1119590370 723638732 1453765533
#> [463] -2023412185 -2100820912 386813166 1520150939 1699700733 1755736810 944307592
#> [470] 71265073 -852024413 -132947036 -1452429742 665849255 -1684788751 -1073373898
#> [477] -59251244 127732581 1417917295 759172520 -117533946 1085490739 850234517
#> [484] -1411599118 -1385851584 1675999913 737997595 -2141420308 -738711302 1918712111
#> [491] -42205895 -700223666 261424540 -1689549043 1408225655 299844992 1210471390
#> [498] -321905493 1988356013 -1590354918 2121011928 -244982975 -1602266125 -535976428
#> [505] 722567074 -1491140425 -1786914175 1592560262 1014221508 1837607925 1299710559
#> [512] -2140547912 -1577094762 1282993059 -1180037275 -1463843198 704369648 1031357849
#> [519] 1136208779 -230119812 -174908246 15101663 -1099373463 -1031831938 -1530923412
#> [526] -235685187 -1088993401 488162160 1782592014 -1705181381 407536669 340643018
#> [533] 1788172264 1715512529 -719736637 -1038633020 118314098 1718750535 830021905
#> [540] 101057686 54508020 -1296970875 -519437617 1729814472 -1702005146 441833619
#> [547] -987248651 -819666478 1875905056 786310153 1498749243 1222257804 318032154
#> [554] 142413711 261460185 1226964846 -1095604484 -1834023827 2063458327 979433952
#> [561] 1432159678 2088536971 -1240900595 -793899974 -885613448 1930475553 1352995539
#> [568] 229622260 319957634 -693254377 -382136863 1691869990 554860068 -1091032875
#> [575] 1822951551 831311128 1152844854 506464963 888678149 1918229154 -1533691760
#> [582] 1070655545 -190261013 1049278940 261300234 1059798783 752742217 -501578530
#> [589] -431555956 -705884579 -4492185 -1729300080 270977454 992291931 2084613181
#> [596] 145179306 100745032 -1285155983 1591768291 -1060078620 393964306 -2003196185
#> [603] -1390792527 -1887386890 -1145780972 416381477 410363695 -1487193880 2109290950
#> [610] 1397274739 -1748348203 558117042 1796101248 1509222505 -1545763621 1735608364
#> [617] -1348732870 -1116989713 -1568466567 -957413874 -282286116 -759885747 534827959
#> [624] 330886464 1804143646 -267855448
Wraps content in a raw attribute block, which protects it from being escaped
by Pandoc. See https://pandoc.org/MANUAL.html#generic-raw-attribute.
Functions raw_latex()
and raw_html()
are shorthands of
raw_block(x, 'latex')
and raw_block(x, 'html')
, respectively.
raw_block(x, type = "latex", ...)
raw_latex(x, ...)
raw_html(x, ...)
x |
The character vector to be protected. |
type |
The type of raw blocks (i.e., the Pandoc output format). If you
are not sure about the Pandoc output format of your document, insert a code
chunk |
... |
Arguments to be passed to |
knitr::raw_latex("\\emph{some text}")
#> [1] "\n```{=latex}\n\\emph{some text}\n```\n"
#> attr(,"class")
#> [1] "knit_asis"
#> attr(,"knit_cacheable")
#> [1] NA
These functions provide a mechanism to protect the character output of R code
chunks. The output is annotated with special markers in raw_output
;
extract_raw_output()
will extract raw output wrapped in the markers,
and replace the raw output with its MD5 digest; restore_raw_output()
will restore the MD5 digest with the original raw output.
extract_raw_output(text, markers = raw_markers)
restore_raw_output(text, chunks, markers = raw_markers)
raw_output(x, markers = raw_markers, ...)
text |
For |
markers |
A length-2 character vector to be used to wrap |
chunks |
A named character vector returned from
|
x |
The character vector to be protected. |
... |
Arguments to be passed to |
This mechanism is designed primarily for R Markdown pre/post-processors. In
an R code chunk, you generate raw_output()
to the Markdown output. In
the pre-processor, you can extract_raw_output()
from the Markdown
file, store the raw output and MD5 digests, and remove the actual raw output
from Markdown so Pandoc will never see it. In the post-processor, you can
read the Pandoc output (e.g., an HTML or RTF file), and restore the raw
output.
For extract_raw_output()
, a list of two components:
value
(the text
with raw output replaced by MD5 digests) and
chunks
(a named character vector, of which the names are MD5 digests
and values are the raw output). For restore_raw_output()
, the
restored text
.
library(knitr)
out = c("*hello*", raw_output("<special>content</special> *protect* me!"),
"*world*")
pre = extract_raw_output(out)
str(pre)
#> List of 2
#> $ value : chr "*hello*\n!!!!!RAW-KNITR-CONTENTc249d7ecacd5f3afb5274321fec9b601RAW-KNITR-CONTENT!!!!!\n*world*"
#> $ chunks: Named chr "<special>content</special> *protect* me!"
#> ..- attr(*, "names")= chr "c249d7ecacd5f3afb5274321fec9b601"
pre$value = gsub("[*]([^*]+)[*]", "<em>\\1</em>",
pre$value) # think this as Pandoc conversion
pre$value
#> [1] "<em>hello</em>\n!!!!!RAW-KNITR-CONTENTc249d7ecacd5f3afb5274321fec9b601RAW-KNITR-CONTENT!!!!!\n<em>world</em>"
# raw output was protected from the conversion
# (e.g. *protect* was not converted)
restore_raw_output(pre$value, pre$chunks)
#> [1] "<em>hello</em>\n<special>content</special> *protect* me!\n<em>world</em>"
Chunks can be put in an external script, and this function reads chunks into
the current knitr session; read_demo()
is a convenience function
to read a demo script from a package.
read_chunk(
path,
lines = read_utf8(path),
labels = NULL,
from = NULL,
to = NULL,
from.offset = 0L,
to.offset = 0L,
roxygen_comments = TRUE
)
read_demo(topic, package = NULL, ...)
path |
Path to the R script. |
lines |
Character vector of lines of code. By default, this is read from
|
labels |
Character vector of chunk labels (default |
from , to |
Numeric vector specifying the starting/ending line numbers of code chunks, or a character vector; see Details. |
from.offset , to.offset |
Offsets to be added to |
roxygen_comments |
Logical dictating whether to keep trailing roxygen-style comments from code chunks in addition to whitespace |
topic , package |
Name of the demo and the package. See
|
... |
Arguments passed to |
There are two approaches to read external code into the current session: (1)
Use a special separator of the from ## ---- chunk-label
(at least four
dashes before the chunk label) in the script; (2) Manually specify the
labels, starting and ending positions of code chunks in the script.
The second approach will be used only when labels
is not NULL
.
For this approach, if from
is NULL
, the starting position is 1;
if to
is NULL
, each of its element takes the next element of
from
minus 1, and the last element of to
will be the length of
lines
(e.g. when from = c(1, 3, 8)
and the script has 10 lines
in total, to
will be c(2, 7, 10)
). Alternatively, from
and to
can be character vectors as regular expressions to specify the
positions; when their length is 1, the single regular expression will be
matched against the lines
vector, otherwise each element of
from
/to
is matched against lines
and the match is
supposed to be unique so that the numeric positions returned from
grep()
will be of the same length of from
/to
. Note
labels
always has to match the length of from
and to
.
As a side effect, code chunks are read into the current session so that future chunks can (re)use the code by chunk label references. If an external chunk has the same label as a chunk in the current session, chunk label references by future chunks will refer to the external chunk.
This function can only be used in a chunk which is not cached
(chunk option cache = FALSE
), and the code is read and stored in the
current session without being executed (to actually run the code,
you have to use a chunk with a corresponding label).
Yihui Xie; the idea of the second approach came from Peter Ruckdeschel (author of the SweaveListingUtils package)
https://yihui.org/knitr/demo/externalization/
## put this in foo.R and read_chunk('foo.R')
## ---- my-label ----
1 + 1
#> [1] 2
lm(y ~ x, data = data.frame(x = 1:10, y = rnorm(10)))
#> Call:
#> lm(formula = y ~ x, data = data.frame(x = 1:10, y = rnorm(10)))
#>
#> Coefficients:
#> (Intercept) x
#> -1.4049 0.1845
## later you can use <<my-label>>= to reference this chunk
## the 2nd approach
code = c("#@a", "1+1", "#@b", "#@a", "rnorm(10)", "#@b")
read_chunk(lines = code, labels = "foo") # put all code into one chunk named foo
read_chunk(lines = code, labels = "foo", from = 2, to = 2) # line 2 into chunk foo
read_chunk(lines = code, labels = c("foo", "bar"), from = c(1, 4), to = c(3, 6))
# automatically figure out 'to'
read_chunk(lines = code, labels = c("foo", "bar"), from = c(1, 4))
read_chunk(lines = code, labels = c("foo", "bar"), from = "^#@a", to = "^#@b")
read_chunk(lines = code, labels = c("foo", "bar"), from = "^#@a", to = "^#@b",
from.offset = 1, to.offset = -1)
## later you can use, e.g., <<foo>>=
knitr::knit_code$get() # use this to check chunks in the current session
#> $foo
#> [1] "1+1"
#>
#> $bar
#> [1] "rnorm(10)"
knitr::knit_code$restore() # clean up the session
Call knit()
to compile the ‘.Rnw’ input to ‘.tex’,
and then tinytex::latexmk()
to convert ‘.tex’ to
‘.pdf’.
rnw2pdf(
input,
output = with_ext(input, "pdf"),
compiler = "xelatex",
envir = parent.frame(),
quiet = FALSE,
clean = TRUE,
error = FALSE,
...
)
input |
Path to the input file. |
output |
Path of the PDF output file. By default, it uses the same name
as the |
compiler , ... |
The LaTeX engine and other arguments to be passed to
|
envir |
Environment in which code chunks are to be evaluated, for
example, |
quiet |
Boolean; suppress the progress bar and messages? |
clean |
If |
error |
If |
This function is similar to knit2pdf()
, with the following differences:
The default compiler is "xelatex" instead of "pdflatex".
output
uses the file extension ".pdf" instead of ".tex".
Before knitting, it tries to remove the output
file and will throw a clear error if the file cannot be removed.
output
could be under any dir, not necessarily the same directory as input
.
It cleans up intermediate files by default, including the ".tex" file.
It stops knitting when any error occurs (by setting the chunk option error = FALSE
).
The output
file path.
The classic Docco style is a two-column layout, with text in the left and code in the right column.
rocco(input, ...)
input |
Path of the input R Markdown file. |
... |
Arguments to be passed to |
The output HTML page supports resizing and hiding/showing the two columns.
Move the cursor to the center of the page, and it will change to a
bidirectional resize cursor; drag the cursor to resize the two columns. Press
the key t
to hide the code column (show the text column only), and
press again to hide the text column (show code).
An HTML file is written, and its name is returned.
Weicheng Zhu and Yihui Xie
The Docco package by Jeremy Ashkenas: https://github.com/jashkenas/docco
rocco_view = function(input) {
owd = setwd(tempdir())
on.exit(setwd(owd))
if (!file.exists(input))
return()
o = rocco(input, quiet = TRUE)
if (interactive())
browseURL(o)
}
# knit these two vignettes using the docco style
rocco_view(system.file("doc", "docco-classic.Rmd", package = "knitr"))
#> You changed the working directory to /tmp/RtmpVgtLjg (probably via setwd()). It will be restored to /home/runner/work/_temp/Library/knitr/doc. See the Note section in ?knitr::knit
rocco_view(system.file("doc", "knit_expand.Rmd", package = "knitr"))
Convert reST to PDF using rst2pdf
(which converts from rst to PDF
using the ReportLab open-source library).
rst2pdf(input, command = "rst2pdf", options = "")
input |
The input rst file. |
command |
Character string giving the path of the
|
options |
Extra command line options, e.g. |
An input file ‘*.rst’ will produce ‘*.pdf’ and this output filename is returned if the conversion was successful.
Alex Zvoleff and Yihui Xie
https://github.com/rst2pdf/rst2pdf
We do not have to use the chunk option names given in knitr; we can set aliases for them. The aliases are a named character vector; the names are aliases and the elements in this vector are the real option names.
set_alias(...)
... |
Named arguments. Argument names are aliases, and argument values are real option names. |
NULL
. opts_knit$get('aliases')
is modified as the side effect.
set_alias(w = "fig.width", h = "fig.height")
# then we can use options w and h in chunk headers instead of fig.width and
# fig.height
Some output documents may need appropriate header information. For example, for LaTeX output, we need to write ‘\usepackage{tikz}’ into the preamble if we use tikz graphics; this function sets the header information to be written into the output.
set_header(...)
... |
Header components; currently possible components are
|
By default, knitr will set up the header automatically. For example, if
the tikz device is used, knitr will add ‘\usepackage{tikz}’ to
the LaTeX preamble, and this is done by setting the header component
tikz
to be a character string: set_header(tikz =
'\usepackage{tikz}')
. Similary, when we highlight R code using the
highlight package (i.e. the chunk option highlight = TRUE
),
knitr will set the highlight
component of the header vector
automatically; if the output type is HTML, this component will be different
– instead of LaTeX commands, it contains CSS definitions.
For power users, all the components can be modified to adapt to a customized
type of output. For instance, we can change highlight
to LaTeX
definitions of the listings package (and modify the output hooks
accordingly), so we can decorate R code using the listings package.
The header vector in opts_knit
is set.
set_header(tikz = "\\usepackage{tikz}")
opts_knit$get("header")
#> highlight
#> "\\definecolor{fgcolor}{rgb}{0, 0, 0}\n\\newcommand{\\hlnum}[1]{\\textcolor[rgb]{0.502,0,0.502}{\\textbf{#1}}}%\n\\newcommand{\\hlsng}[1]{\\textcolor[rgb]{0.651,0.522,0}{#1}}%\n\\newcommand{\\hlcom}[1]{\\textcolor[rgb]{1,0.502,0}{#1}}%\n\\newcommand{\\hlopt}[1]{\\textcolor[rgb]{1,0,0.502}{\\textbf{#1}}}%\n\\newcommand{\\hldef}[1]{\\textcolor[rgb]{0,0,0}{#1}}%\n\\newcommand{\\hlkwa}[1]{\\textcolor[rgb]{0.733,0.475,0.467}{\\textbf{#1}}}%\n\\newcommand{\\hlkwb}[1]{\\textcolor[rgb]{0.502,0.502,0.753}{\\textbf{#1}}}%\n\\newcommand{\\hlkwc}[1]{\\textcolor[rgb]{0,0.502,0.753}{#1}}%\n\\newcommand{\\hlkwd}[1]{\\textcolor[rgb]{0,0.267,0.4}{#1}}%\n\\let\\hlipl\\hlkwb"
#> tikz
#> "\\usepackage{tikz}"
#> framed
#> ""
This function extracts the LaTeX preamble of the parent document to use for the child document, so that the child document can be compiled as an individual document.
set_parent(parent)
parent |
Path to the parent document, relative to the current child document. |
When the preamble of the parent document also contains code chunks and inline R code, they will be evaluated as if they were in this child document. For examples, when knitr hooks or other options are set in the preamble of the parent document, it will apply to the child document as well.
The preamble is extracted and stored to be used later when the complete output is written.
Obviously this function is only useful when the output format is LaTeX.
This function only works when the child document is compiled in a
standalone mode using knit()
(instead of being called in
knit_child()
); when the parent document is compiled, this
function in the child document will be ignored.
https://yihui.org/knitr/demo/child/
## can use, e.g. \Sexpr{set_parent('parent_doc.Rnw')} or
# <<setup-child, include=FALSE>>=
# set_parent('parent_doc.Rnw')
# @
This function is mainly for internal use: it is called on each part of the output of the code chunk (code, messages, text output, and plots, etc.) after all statements in the code chunk have been evaluated, and will sew these pieces of output together into a character vector.
sew(x, options = list(), ...)
x |
Output from |
options |
A list of chunk options used to control output. |
... |
Other arguments to pass to methods. |
This function takes a specially formatted R script and converts it to a
literate programming document. By default normal text (documentation) should
be written after the roxygen comment (#'
) and code chunk options are
written after #|
or #+
or # %%
or # ----
.
spin(
hair,
knit = TRUE,
report = TRUE,
text = NULL,
envir = parent.frame(),
format = c("Rmd", "Rnw", "Rhtml", "Rtex", "Rrst", "qmd"),
doc = "^#+'[ ]?",
inline = "^[{][{](.+)[}][}][ ]*$",
comment = c("^[# ]*/[*]", "^.*[*]/ *$"),
precious = !knit && is.null(text)
)
hair |
Path to the R script. The script must be encoded in UTF-8 if it contains multibyte characters. |
knit |
Logical; whether to compile the document after conversion. |
report |
Logical; whether to generate a report for ‘Rmd’,
‘Rnw’ and ‘Rtex’ output. Ignored if |
text |
A character vector of code, as an alternative way to provide the
R source. If |
envir |
Environment for |
format |
Character; the output format. The default is R Markdown. |
doc |
A regular expression to identify the documentation lines; by
default it follows the roxygen convention, but it can be customized, e.g.
if you want to use |
inline |
A regular expression to identify inline R expressions; by
default, code of the form |
comment |
A pair of regular expressions for the start and end delimiters
of comments; the lines between a start and an end delimiter will be
ignored. By default, the delimiters are |
precious |
logical: whether intermediate files (e.g., |
Obviously the goat's hair is the original R script, and the wool is the literate programming document (ready to be knitted).
If text
is NULL
, the path of the final output document,
otherwise the content of the output.
If the output format is Rnw
and no document class is specified
in roxygen comments, this function will automatically add the
article
class to the LaTeX document so that it is complete and can
be compiled. You can always specify the document class and other LaTeX
settings in roxygen comments manually.
When the output format is Rmd
, it is compiled to HTML via
knit2html()
, which uses R Markdown v1 instead of v2. If you
want to use the latter, you should call
rmarkdown::render()
instead. Similarly, if the
output format is qmd
, you need to render the output with Quarto.
Yihui Xie, with the original idea from Richard FitzJohn (who named it
as sowsear()
which meant to make a silk purse out of a sow's ear)
https://yihui.org/knitr/demo/stitch/
stitch
(feed a template with an R script)
This function is similar to knit_child()
but is used in R
scripts instead. When the main R script is not called via
spin()
, this function simply executes the child script via
sys.source()
, otherwise it calls spin()
to spin
the child script into a source document, and uses knit_child()
to compile it. You can call this function in R code, or using the syntax of
inline R expressions in spin()
(e.g.
{{knitr::spin_child('script.R')}}
).
spin_child(input, format)
input |
Filename of the input R script. |
format |
Passed to |
A character string of the knitted R script.
This is a convenience function for small-scale automatic reporting based on
an R script and a template. The default template is an Rnw file (LaTeX);
stitch_rhtml()
and stitch_rmd()
are wrappers on top of
stitch()
using the R HTML and R Markdown templates respectively.
stitch(
script,
template = system.file("misc", "knitr-template.Rnw", package = "knitr"),
output = NULL,
text = NULL,
envir = parent.frame()
)
stitch_rhtml(..., envir = parent.frame())
stitch_rmd(..., envir = parent.frame())
script |
Path to the R script. |
template |
Path of the template to use. By default, the Rnw template in this package; there is also an HTML template in knitr. |
output |
Output filename, passed to |
text |
A character vector. This is an alternative way to provide the input file. |
envir |
Environment in which code chunks are to be evaluated, for
example, |
... |
Arguments passed to |
The first two lines of the R script can contain the title and author of the report in comments of the form ‘## title:’ and ‘## author:’. The template must have a token ‘%sCHUNK_LABEL_HERE’, which will be used to input all the R code from the script. See the examples below.
The R script may contain chunk headers of the form ‘## ---- label, opt1=val1, opt2=val2’, which will be copied to the template; if no chunk headers are found, the whole R script will be inserted into the template as one code chunk.
path of the output document
spin
(turn a specially formatted R script to a report)
s = system.file("misc", "stitch-test.R", package = "knitr")
if (interactive()) stitch(s) # compile to PDF
# HTML report
stitch(s, system.file("misc", "knitr-template.Rhtml", package = "knitr"))
#> 1/7 [setup]
#>
#> | options(width=90)
#> | if (!exists('.knitr.title')) .knitr.title = 'A Report Generated by knitr'
#> | .knitr.author = if (exists('.knitr.author')) paste('by', .knitr.author) else ''
#> 2/7
#>
#> | I(.knitr.title) #128:158
#> | packageVersion('knitr') #326:364
#> | I(.knitr.author) #371:402
#> 3/7 [auto-report]
#>
#> | set.seed(1121)
#> | (x = rnorm(20))
#> | mean(x);var(x)
#> | boxplot(x)
#> | hist(x, main = '')
#> |
#> 4/7
#>
#> 5/7 [session-info]
#>
#> | sessionInfo()
#> | Sys.time()
#> 6/7 [clean-up]
#>
#> | rm(.knitr.author); rm(.knitr.author)
#> 7/7
#>
#> Chunk clean-up:
#> Warning in rm(.knitr.author): object '.knitr.author' not found
#>
#> rm(.knitr.author); rm(.knitr.author)
#>
#> Number of messages:
#> warning
#> 1
#> [1] "stitch-test.html"
# or convert markdown to HTML
stitch(s, system.file("misc", "knitr-template.Rmd", package = "knitr"))
#> 1/5
#>
#> | if (exists('.knitr.title')) I(paste('#', .knitr.title, sep = '')) #1:69
#> | if (exists('.knitr.author')) I(.knitr.author) #72:120
#> | packageVersion('knitr') #201:227
#> 2/5 [auto-report]
#>
#> | set.seed(1121)
#> | (x = rnorm(20))
#> | mean(x);var(x)
#> | boxplot(x)
#> | hist(x, main = '')
#> |
#> 3/5
#>
#> 4/5 [session-info]
#>
#> | sessionInfo()
#> | Sys.time()
#> 5/5 [clean-up]
#>
#> | if (exists('.knitr.title')) rm(.knitr.author)
#> | if (exists('.knitr.author')) rm(.knitr.author)
#> [1] "stitch-test.md"
unlink(c("stitch-test.html", "stitch-test.md", "figure"), recursive = TRUE)
Since R 3.0.0, package vignettes can use non-Sweave engines, and knitr
has provided a few engines to compile vignettes via knit()
with
different templates. See https://yihui.org/knitr/demo/vignette/ for
more information.
If you use the knitr::rmarkdown
engine, please make sure that
you put rmarkdown in the ‘Suggests’ field of your
‘DESCRIPTION’ file. Also make sure pandoc
is available
during R CMD build
. If you build your package from RStudio, this
is normally not a problem. If you build the package outside RStudio, run
rmarkdown::find_pandoc()
in an R session to check if Pandoc can be
found.
When the rmarkdown package is not installed or not available, or
pandoc
cannot be found, the knitr::rmarkdown
engine will
fall back to the knitr::knitr
engine, which uses R Markdown v1 based
on the markdown package.
library(knitr)
vig_list = tools::vignetteEngine(package = "knitr")
str(vig_list)
#> List of 8
#> $ knitr::rmarkdown :List of 6
#> ..$ name : chr "rmarkdown"
#> ..$ package: chr "knitr"
#> ..$ pattern: chr "[.][Rr](md|markdown)$"
#> ..$ weave :function (...)
#> ..$ tangle :function (file, ..., encoding = "UTF-8", quiet = FALSE)
#> ..$ aspell :List of 1
#> .. ..$ filter:function (ifile, encoding = "UTF-8")
#> $ knitr::docco_classic_notangle:List of 6
#> ..$ name : chr "docco_classic_notangle"
#> ..$ package: chr "knitr"
#> ..$ pattern: chr "[.][Rr]mk?d$"
#> ..$ weave :function (file, driver, syntax, encoding = "UTF-8", quiet = FALSE, ...)
#> ..$ tangle :function (file, ...)
#> ..$ aspell :List of 1
#> .. ..$ filter:function (ifile, encoding = "UTF-8")
#> $ knitr::docco_linear_notangle :List of 6
#> ..$ name : chr "docco_linear_notangle"
#> ..$ package: chr "knitr"
#> ..$ pattern: chr "[.][Rr](md|markdown)$"
#> ..$ weave :function (file, driver, syntax, encoding = "UTF-8", quiet = FALSE, ...)
#> ..$ tangle :function (file, ...)
#> ..$ aspell :List of 1
#> .. ..$ filter:function (ifile, encoding = "UTF-8")
#> $ knitr::knitr :List of 6
#> ..$ name : chr "knitr"
#> ..$ package: chr "knitr"
#> ..$ pattern: chr "[.]([rRsS](nw|tex)|[Rr](md|html|rst))$"
#> ..$ weave :function (file, driver, syntax, encoding = "UTF-8", quiet = FALSE, ...)
#> ..$ tangle :function (file, ..., encoding = "UTF-8", quiet = FALSE)
#> ..$ aspell :List of 1
#> .. ..$ filter:function (ifile, encoding = "UTF-8")
#> $ knitr::docco_classic :List of 6
#> ..$ name : chr "docco_classic"
#> ..$ package: chr "knitr"
#> ..$ pattern: chr "[.][Rr]mk?d$"
#> ..$ weave :function (file, driver, syntax, encoding = "UTF-8", quiet = FALSE, ...)
#> ..$ tangle :function (file, ..., encoding = "UTF-8", quiet = FALSE)
#> ..$ aspell :List of 1
#> .. ..$ filter:function (ifile, encoding = "UTF-8")
#> $ knitr::rmarkdown_notangle :List of 6
#> ..$ name : chr "rmarkdown_notangle"
#> ..$ package: chr "knitr"
#> ..$ pattern: chr "[.][Rr](md|markdown)$"
#> ..$ weave :function (...)
#> ..$ tangle :function (file, ...)
#> ..$ aspell :List of 1
#> .. ..$ filter:function (ifile, encoding = "UTF-8")
#> $ knitr::knitr_notangle :List of 6
#> ..$ name : chr "knitr_notangle"
#> ..$ package: chr "knitr"
#> ..$ pattern: chr "[.]([rRsS](nw|tex)|[Rr](md|html|rst))$"
#> ..$ weave :function (file, driver, syntax, encoding = "UTF-8", quiet = FALSE, ...)
#> ..$ tangle :function (file, ...)
#> ..$ aspell :List of 1
#> .. ..$ filter:function (ifile, encoding = "UTF-8")
#> $ knitr::docco_linear :List of 6
#> ..$ name : chr "docco_linear"
#> ..$ package: chr "knitr"
#> ..$ pattern: chr "[.][Rr](md|markdown)$"
#> ..$ weave :function (file, driver, syntax, encoding = "UTF-8", quiet = FALSE, ...)
#> ..$ tangle :function (file, ..., encoding = "UTF-8", quiet = FALSE)
#> ..$ aspell :List of 1
#> .. ..$ filter:function (ifile, encoding = "UTF-8")
vig_list[["knitr::knitr"]][c("weave", "tangle")]
#> $weave
#> function (file, driver, syntax, encoding = "UTF-8", quiet = FALSE,
#> ...)
#> {
#> {
#> on.exit({
#> opts_chunk$restore()
#> knit_hooks$restore()
#> }, add = TRUE)
#> oopts = options(knitr.knit2html.force_v1 = TRUE)
#> on.exit(options(oopts), add = TRUE)
#> }
#> opts_chunk$set(error = FALSE)
#> knit_hooks$set(purl = function(...) {
#> hook_purl(...)
#> for (i in c("optipng", "pngquant")) if (!is.function(knit_hooks$get(i)) &&
#> Sys.which(i) != "") {
#> switch(i, optipng = hook_optipng(...), pngquant = hook_pngquant(...))
#> }
#> })
#> (if (grepl("\\.[Rr]md$", file))
#> knit2html
#> else if (grepl("\\.[Rr]rst$", file))
#> knit2pandoc
#> else knit)(file, encoding = encoding, quiet = quiet, envir = globalenv(),
#> ...)
#> }
#> <bytecode: 0x55f86b151670>
#> <environment: namespace:knitr>
#>
#> $tangle
#> function (file, ..., encoding = "UTF-8", quiet = FALSE)
#> {
#> purl(file, encoding = encoding, quiet = quiet, ...)
#> }
#> <bytecode: 0x55f86b155910>
#> <environment: namespace:knitr>
vig_list[["knitr::knitr_notangle"]][c("weave", "tangle")]
#> $weave
#> function (file, driver, syntax, encoding = "UTF-8", quiet = FALSE,
#> ...)
#> {
#> {
#> on.exit({
#> opts_chunk$restore()
#> knit_hooks$restore()
#> }, add = TRUE)
#> oopts = options(knitr.knit2html.force_v1 = TRUE)
#> on.exit(options(oopts), add = TRUE)
#> }
#> opts_chunk$set(error = FALSE)
#> {
#> }
#> (if (grepl("\\.[Rr]md$", file))
#> knit2html
#> else if (grepl("\\.[Rr]rst$", file))
#> knit2pandoc
#> else knit)(file, encoding = encoding, quiet = quiet, envir = globalenv(),
#> ...)
#> }
#> <environment: namespace:knitr>
#>
#> $tangle
#> function (file, ...)
#> {
#> unlink(with_ext(file, "R"))
#> return()
#> }
#> <bytecode: 0x55f86b17c010>
#> <environment: namespace:knitr>
vig_list[["knitr::docco_classic"]][c("weave", "tangle")]
#> $weave
#> function (file, driver, syntax, encoding = "UTF-8", quiet = FALSE,
#> ...)
#> {
#> {
#> on.exit({
#> opts_chunk$restore()
#> knit_hooks$restore()
#> }, add = TRUE)
#> oopts = options(knitr.knit2html.force_v1 = TRUE)
#> on.exit(options(oopts), add = TRUE)
#> }
#> opts_chunk$set(error = FALSE)
#> knit_hooks$set(purl = function(...) {
#> hook_purl(...)
#> for (i in c("optipng", "pngquant")) if (!is.function(knit_hooks$get(i)) &&
#> Sys.which(i) != "") {
#> switch(i, optipng = hook_optipng(...), pngquant = hook_pngquant(...))
#> }
#> })
#> rocco(file, encoding = encoding, quiet = quiet, envir = globalenv(),
#> ...)
#> }
#> <bytecode: 0x55f86b1657f8>
#> <environment: namespace:knitr>
#>
#> $tangle
#> function (file, ..., encoding = "UTF-8", quiet = FALSE)
#> {
#> purl(file, encoding = encoding, quiet = quiet, ...)
#> }
#> <bytecode: 0x55f86b155910>
#> <environment: namespace:knitr>
This function wraps long paragraphs in an R Markdown file. Other elements are not wrapped: the YAML preamble, fenced code blocks, section headers and indented elements. The main reason for wrapping long lines is to make it easier to review differences in version control.
wrap_rmd(file, width = 80, text = NULL, backup)
file |
The input Rmd file. |
width |
The expected line width. |
text |
A character vector of text lines, as an alternative to |
backup |
Path to back up the original file in case anything goes
wrong. If set to |
If file
is provided, it is overwritten; if text
is
provided, a character vector is returned.
Currently it does not wrap blockquotes or lists (ordered or unordered). This feature may or may not be added in the future.
wrap_rmd(text = c("```", "1+1", "```", "- a list item", "> a quote", "",
paste(rep("this is a normal paragraph", 5), collapse = " ")))
#> [1] "```"
#> [2] "1+1"
#> [3] "```"
#> [4] "- a list item"
#> [5] "> a quote"
#> [6] ""
#> [7] "this is a normal paragraph this is a normal paragraph this is a normal"
#> [8] "paragraph this is a normal paragraph this is a normal paragraph"
A wrapper function of xfun::pkg_bib()
.
write_bib(..., prefix = getOption("knitr.bib.prefix", "R-"))
... , prefix |
Arguments passed to |