title | description | prev | next | type | id |
---|---|---|---|---|---|
Chapter 8: R Markdown basics |
This chapter will teach you the basics of R Markdown and how it can make your student life easlier. |
/chapter7 |
/chapter9 |
chapter |
8 |
-
R Markdown allows you to create reproducible reports.
-
Help you organise your code in code chunk.
-
You can run python code in R. Or any other languages in R.
-
Rendering multiple files with a few line of code instead of copying and pasting all the time.
-
Support different files output including
html
andpdf
. -
And so much more.
```{r, this-is-an-r-chunk}
```
Here is an example for R chunk. An R chunk starts with three
```{r}
and ends with ```
. After r,
is where you
can name the code chunk. Notice that the code chunk name must not
include breaks.
```{r, this-is-an-r-chunk,include = TRUE}
ggplot(mpg, aes(displ, hwy, colour = class)) +
geom_point()
```
ggplot(mpg, aes(displ, hwy, colour = class)) +
geom_point()
The default setting is include = FALSE
. When you set include = TRUE
,
it will print out both code and results. Alternatively, if you wish not
to include the code and results from this R chunk, set
include = FALSE
. R Markdown still runs the code and you can use the
results from this code chunk in other chunks.
```{r, this-is-an-r-chunk,echo = FALSE}
ggplot(mpg, aes(displ, hwy, colour = class)) +
geom_point()
```
The default setting is echo = TRUE
. When you set echo = FALSE
, it
will only print out the results from this code chunk but prevents code
from appearing in the finished file. This is a useful way to embed
figures.
The default setting is eval = TRUE
. If you only want to print out the
code but not run the code, you can set eval = FALSE
. This is helpful
when you are
```{r, this-is-an-r-chunk,messge = FALSE, warning = FALSE, error = FALSE}
ggplot(mpg, aes(displ, hwy, colour = class)) +
geom_point()
```
The defult setting is message = TRUE, warning = TRUE, error = FALSE
.
When you are generating an assignment or report, you would not want to
include messages and warning to be printed out in the final outputs. Set
both message = FALSE
, warning = FALSE
and error = FALSE
will
prevent messages and warnings to be printed out. When set
error = FALSE
, rmarkdown::render()
will halt on error in a code
chunk, and the error will be displayed in the R console. Both messages
and warning
will also be displayed in the console.
```{r, this-is-an-r-chunk,cache = TRUE}
ggplot(mpg, aes(displ, hwy, colour = class)) +
geom_point()
```
The default setting is cach = FALSE
. Everytime when you Knit
a R
Markdown document, it will run through all the code chunks. When some of
your code chunk takes too much time to run or you don't need to re-run
the code every time when you knit the document, you can set
cache = TRUE
to loaded from previously saved databases (.rdb
and
.rdx
files). This means that this code chunk will only be evaluated
the first time you knit the document.
```{r, this-is-an-r-chunk,fig.width = 4, fig.height =4}
ggplot(mpg, aes(displ, hwy, colour = class)) +
geom_point()
```
ggplot(mpg, aes(displ, hwy, colour = class)) +
geom_point()
The default setting is fig.width =7,fig.height =7
. The figures are
defined in inches. fig.width
defines the figure's width where
fig.height
defines the figure's hight.
```{r, this-is-an-r-chunk,out.width = '50%'}
ggplot(mpg, aes(displ, hwy, colour = class)) +
geom_point()
```
ggplot(mpg, aes(displ, hwy, colour = class)) +
geom_point()
You can also scale your output figures with out.width
and
out.height
. out.width = '50%'
means 50% of the page width. You can
also scale by out.height = '50%'
which means 50% of the page height.
You can add website links in your R Markdown using syntax:
[Text](link)
. Inside []
is the text you want to display for the
hyperlink and the actual link goes into ()
.
There are two ways you can insert images/figures in your R Markdown file.
-
data:image/s3,"s3://crabby-images/deb24/deb24a4d8c90ef28266bc901622221a27596dba8" alt="alt text here"
the path to your image will be a relative path where you stored your images including file name. For example,data:image/s3,"s3://crabby-images/f57b6/f57b61ed3968bcca0cf9287b1d174faecb4d13eb" alt="R Markdown"
-
You could also use code chunk to include images.
```{r, echo=FALSE, out.width="50%"}
knitr::include_graphics("images/rmarkdown.png")
```
You can select different html
templates or you can use pdf
outputs
for your presentations.