# run this only once
install.packages("tinytex")
tinytex::install_tinytex()
3 Elements of an quarto file
- learn the basics of using quarto
3.1 YAML
The YAML is metadata for the document that goes right at the top of the file between two sets of three dashes. The YAML consists of key: values
pairs. The colon and space are required. Rstudio will autocomplete the keys.
---
title: "My Manuscript"
format: html
date: 2022-04-03
---
The YAML can set the document author and title, the output format and many other things.
YAML is sensitive to white space. For example, you must have the space after the colon.
With the keyword today
, you can make the document report the date it was rendered.
---
title: "My Manuscript"
format: html
date: today
---
Add date and author keys to the YAML of your svalbard_traits quarto document so that the rendered document shows today’s date and your name.
3.1.1 Output formats
Quarto documents can be rendered in about 40 formats! The format can be specified when the quarto file is created in RStudio or by editing the YAML.
Producing an html file to view in a browser is the simplest, as no extra software needs installing. The YAML should look something like this.
---
title: "My Manuscript"
format: html
---
Word documents are also easy; just change the format to docx
. This can be very useful if you have a supervisor or collaborators who cannot cope with markdown directly.
There are two ways to render a quarto file as a PDF. The easiest is to change the format to typst
.
---
title: "My Manuscript"
format: typst
---
Typst comes bundled with quarto. It is very fast and easier to debug than the alternative. However, typst is very new and not yet supported by many journals for manuscript submission.
LaTeX is an alternative way to produce PDF from quarto documents (you don’t need to learn any LaTeX). It requires some external tools to be installed, which can be done with the tinytxt
package.
Then the format in the YAML can be changed to pdf
.
---
title: "My Manuscript"
format: pdf
---
You don’t need to know any LaTeX, but you can include some if you want to change the formatting etc. For example, you force a new page, you could use the command.
\\newpage
With PDF documents, it can be tricky to control exactly where the figures are positioned, so I recommend working with html as long as possible.
Perhaps the best way to collaborate with coauthors on a quarto document is to use version control for example with GitHub.
An alternative is to use the trackdown
package to upload markdown files to Google Drive where they can be edited and then downloaded again.
3.2 Text
Type to make text! In the visual editor, you can format the text in much the same way you would work in MS word or LibreOffice. RStudio has a built-in spell checker that will underline words it doesn’t recognise in red.
A comment in an R code block starts with a #
, just as in an ordinary R script.
A comment in the text is enclosed an html comment mark
<!-- This is a comment -->
Select some text and type to make it a comment.
In the source editor, you can select text you want to hide and use this keyboard short-cut to comment it out.
3.2.1 Source editor
Sometimes it is useful to be able to write in markdown directly, rather than using the visual editor, for example if you are writing a question for stackoverflow.com or an issue on github.com. You can see this mode by clicking on “Source” above the document
Paragraphs have a blank line between them. It is good practice to write one sentence per line. The extra line breaks will be removed when the document in knitted. If you want to force a line break, put two spaces or a backslash at the end of the line.
Formatting is generated with some special characters. For example:
Markdown Syntax | Output |
---|---|
|
Header 1 |
|
Header 2 |
|
Header 3 |
*italics* and **bold** | italics and bold |
superscript m^2^ | superscript m2 |
subscript CO~2~ | subscript CO2 |
`verbatim code` | verbatim code |
If you actually want a *_^~ in the text, you need to escape it by putting a backslash \ before it, e.g. \*.
A more complete list of formatting is given in the R markdown cheat sheet, and in the quarto documentation.
Vil du har Dato i stedet for Date, og Figur frem for Figure?
Use the lang
tag with nn
for nynorsk or nb
for bokmål. Other languages are available.
---
title: "My Manuscript"
lang: nn
---
You can change the spell checker language for the current project from the RStudio menu with
You can also change the global options to change the language for all projects.
The Results section of the svalbard_traits document should be in Header 1 style, and species names should be in italics. Fix this and render the document to check the formatting has worked.
3.3 Code blocks
Code in an quarto document is contained in code blocks.
This is a code block that loads the tidyverse
package.
```{r}
library(tidyverse)
```
It starts with three back-ticks, followed by braces. Inside the braces, the “r” indicates that this block is in the R language. Next, on a new line, is the body of the code block. The block ends with three back-ticks on their own line.
In the visual editor, you won’t see the back-ticks, but the code block will start with {r}
and have a grey background.
3.3.1 Making a block
You can type the back-ticks and braces needed to make a block, but, when using the visual editor, it is easier to get RStudio to insert the block with the insert tool.
Type a forwards slash // on a blank line and choose “R code chunk”. You can also use the keyboard short-cut .
3.3.2 Block language
We will just work with R code blocks, but it is possible to run block in other languages, including Python and Julia, which would have {python}
and {julia}
instead of {r}
at the start of the chunk.
3.3.3 Running a code block
Code in blocks will be run when the document is rendered (unless eval: false
), but it is also useful to run the code interactively to check that it works. You can do this by clicking on the green play buttons at the top-right of the block (Figure 3.3) or from the Run button above the document. If the code depends on previous block, the grey/green icon will run them all.
Run all the blocks in the document.
Now double click on the object called bistorta
in the RStudio Environment tab so you can view it. These are the data we are working with.
Make a new code block (or blocks) that make a plot showing the effect of the treatment on Bistorta leaf thickness.
Hint
You can copy and modify some of the existing code rather than writing from scratch. You will need to look at the data. Make sure all your chunk labels are unique.
3.3.4 Block options
Code block options control how the blocks work and how any output is treated. Options are given in special comments at the top of the block.
```{r}
#| label: load-data
#| message: false
# load data
traits <- read_delim("data/PFTC4_Svalbard_2018_ITEX_Traits.csv")
```
The white space in the block options is critical.
If you don’t have the space after the
#|
then the option becomes a regular comment and is ignored.If you don’t have a space after the colon, you get “ERROR: Render failed due to invalid YAML.”
true
and false
are written in lower case (in R they are upper case).
The block options must start on the first line of the block after the {r}
.
There are lots of block options, but only a few that you will need to use frequently. Here are some and their default.
-
echo
(true
) Show the block’s code in the output. -
eval
(true
) Run the block’s code. -
include
(true
) Include the output of the block in the document. -
message
(true
) Include messages from R. -
warning
(true
) Include warnings from R. -
output
(true
) How and whether to include results. -
error
(false
) Iftrue
, includes any error message and carries on. Iffalse
, stops knitting when there is an error in R code.
I leave message
and warning
as true
while I am writing the document, so I can see any possible problems, and set them to false
when I render the final version.
I sometimes find it useful to set error
to true
as can make it easier to debug any errors in the code.
Some of these block options interact. Use the following widget, which initially shows the defaults, to explore what is shown with the most commonly used options.
Interactive table: Select your block options
Block output
Block options for figures are shown in Section 4.1.1.
For more options see https://quarto.org/docs/computations/execution-options.html
Importing packages produces lots of output that we don’t need to see in the final report. Use block options to hide the output of this block.
The code block importing the data is giving a message how the data were imported. Use block options to make this message go away.
3.3.5 Setting global block options
Global code block options can be set for all code blocks by including execute
with the option in the YAML at the top of the file.
For example, this YAML would set echo to be false for the entire document (options for individual blocks could override this).
---
title: "My Manuscript"
format: html
execute:
echo: false
---
Use global block options to stop the code from showing in the report.
3.3.6 Block labels
It is a good idea to give code blocks labels which you can do with the label
option. If you don’t, they will automatically be called “unnamed-chunk-n” where “n” is a incrementing number. This is inconvenient for debugging (you need to work out which block is “unnamed-chunk-38”) and for working with any image files generated by the document. In section Chapter 6 you will see how to use block names to cross-reference figures and tables in your document.
3.3.6.1 Rules for block labels
Block labels should be informative and can contain letters and numbers. Words should be separated by hyphens (“-”).
Avoid spaces, underscores, periods and other special characters in code block labels. They will cause all sorts of strange problems.
3.3.7 Hiding a block
If a block has a lot of code, it can be useful to hide it to make it easier to navigate the document. It will still be rendered. The grey arrow next to the line numbers will do this. Sections of text can also be hidden.
3.3.8 Environments and working directory
R renders quarto documents in a new R session. Initially, no packages are loaded and the environment is empty: the quarto document does not have access to any objects in your current environment (this is a good thing for reproducible analyses). This means that any data or packages you want to use in the document needs to be imported by the code in the document.
The working directory for the new R session used when rendering the quarto file is the directory where the quarto file is. If the file is in the root directory of an RStudio project, relative paths will work the same way in the quarto document as from the console. If the quarto file is in a sub-directory, use here::here()
to form paths relative to the project root.
3.4 Inline code
In addition to the output from code blocks, you can insert code directly into text. This lets you avoid copying and pasting numbers from the output. Inline code is enclosed by back-ticks and starts with an r
.
`r 7 * 6` Seven times six is
Seven times six is 42
In the visual editor, you can make inline code by clicking on the </>
icon.
If you want numbers written as words, for example at the start of a sentence, use the package english
.
`r english::Words(7 * 6)` is the answer to seven times six.
Forty-two is the answer to seven times six.
It is best to keep inline code short to keep the text readable.
One trick to shorten inline code is to do all necessary calculations in a previous code block, so only the name of the object with the result needs to be in the inline code. If there are many results to report, consider storing them in a list as in the following example.
`r height_info$n` plants.
We measured `r height_info$min` cm and the maximum `r height_info$max` cm. The minimum height was
We measured 422 plants. The minimum height was 0.1 cm and the maximum 30 cm.
You can also use a glue
chunk with the glue
package. This might be useful when there is a lot of inline R, or if you want to test it before you render the document.
First we need to load the glue
package
Then we can use a glue
chunk with the chunk option output: asis
to format the output as raw markdown. R code is put inside braces {}
.
```{glue}
#| label: glue-example
#| output: asis
We measured {height_info$n} plants. The minimum height was {height_info$min} cm and the maximum {height_info$max} cm.
```
We measured 422 plants. The minimum height was 0.1 cm and the maximum 30 cm.
Only one line of text per glue
chunk.
Use some inline R code to report the number of leaf thickness measurements for Bistorta vivipara.
Numbers should be rounded to an appropriate number of decimal places when reported in the text or a table to avoid spurious precision.
Here are some functions that can help
# use round() to round number to the required number of digits after the decimal point.
round(151.98646, digits = 2)
[1] 151.99
round(151.98646, digits = -1) # negative values round to the left of the decimal point.
[1] 150
# Use signif() to set the required number of significant figures
signif(c(0.15198646, 151.98646), digits = 4)
[1] 0.152 152.000
# format.pval() is a special function for formatting p-values.
# Use the eps argument to set the minimum exact values to display.
format.pval(c(0.194342, 0.00000194342), digits = 3, eps = 0.001)
[1] "0.194" "<0.001"
# format() when you need more control over how the number is displayed
# Norwegian format
format(1504703.232, big.mark = ".", decimal.mark = ",", nsmall = 1)
[1] "1.504.703,2"
Make sure to do all calculations, analyses and figures on the full precision number and only round to display it as text.
The mean Bistorta vivipara height is currently given to the nearest nanometre. This precision is spurious. Edit the inline code in the document so that the mean height and its standard error are shown to two decimal places.