2016-08-19 03:51:47 +08:00
|
|
|
# Workflow: scripts
|
|
|
|
|
2021-02-21 23:40:40 +08:00
|
|
|
So far you've been using the console to run code.
|
|
|
|
That's a great place to start, but you'll find it gets cramped pretty quickly as you create more complex ggplot2 graphics and dplyr pipes.
|
|
|
|
To give yourself more room to work, it's a great idea to use the script editor.
|
|
|
|
Open it up either by clicking the File menu, and selecting New File, then R script, or using the keyboard shortcut Cmd/Ctrl + Shift + N.
|
|
|
|
Now you'll see four panes:
|
2016-08-19 03:51:47 +08:00
|
|
|
|
|
|
|
```{r echo = FALSE, out.width = "75%"}
|
2016-08-20 03:42:43 +08:00
|
|
|
knitr::include_graphics("diagrams/rstudio-editor.png")
|
2016-08-19 03:51:47 +08:00
|
|
|
```
|
|
|
|
|
2021-02-21 23:40:40 +08:00
|
|
|
The script editor is a great place to put code you care about.
|
|
|
|
Keep experimenting in the console, but once you have written code that works and does what you want, put it in the script editor.
|
|
|
|
RStudio will automatically save the contents of the editor when you quit RStudio, and will automatically load it when you re-open.
|
|
|
|
Nevertheless, it's a good idea to save your scripts regularly and to back them up.
|
2016-08-19 03:51:47 +08:00
|
|
|
|
2022-02-16 05:49:31 +08:00
|
|
|
TODO: Add file naming advice
|
|
|
|
|
|
|
|
TODO: Add advice about creating sections
|
|
|
|
|
2016-08-20 03:42:43 +08:00
|
|
|
## Running code
|
2016-08-19 03:51:47 +08:00
|
|
|
|
2021-02-21 23:40:40 +08:00
|
|
|
The script editor is also a great place to build up complex ggplot2 plots or long sequences of dplyr manipulations.
|
|
|
|
The key to using the script editor effectively is to memorise one of the most important keyboard shortcuts: Cmd/Ctrl + Enter.
|
|
|
|
This executes the current R expression in the console.
|
|
|
|
For example, take the code below.
|
|
|
|
If your cursor is at █, pressing Cmd/Ctrl + Enter will run the complete command that generates `not_cancelled`.
|
|
|
|
It will also move the cursor to the next statement (beginning with `not_cancelled %>%`).
|
|
|
|
That makes it easy to run your complete script by repeatedly pressing Cmd/Ctrl + Enter.
|
2016-08-19 03:51:47 +08:00
|
|
|
|
|
|
|
```{r, eval = FALSE}
|
|
|
|
library(dplyr)
|
|
|
|
library(nycflights13)
|
|
|
|
|
|
|
|
not_cancelled <- flights %>%
|
2016-08-20 03:42:43 +08:00
|
|
|
filter(!is.na(dep_delay)█, !is.na(arr_delay))
|
2016-08-19 03:51:47 +08:00
|
|
|
|
|
|
|
not_cancelled %>%
|
|
|
|
group_by(year, month, day) %>%
|
|
|
|
summarise(mean = mean(dep_delay))
|
|
|
|
```
|
|
|
|
|
2021-02-21 23:40:40 +08:00
|
|
|
Instead of running expression-by-expression, you can also execute the complete script in one step: Cmd/Ctrl + Shift + S.
|
|
|
|
Doing this regularly is a great way to check that you've captured all the important parts of your code in the script.
|
2016-08-20 03:42:43 +08:00
|
|
|
|
2021-02-21 23:40:40 +08:00
|
|
|
I recommend that you always start your script with the packages that you need.
|
|
|
|
That way, if you share your code with others, they can easily see what packages they need to install.
|
|
|
|
Note, however, that you should never include `install.packages()` or `setwd()` in a script that you share.
|
|
|
|
It's very antisocial to change settings on someone else's computer!
|
2016-08-20 03:42:43 +08:00
|
|
|
|
2021-02-21 23:40:40 +08:00
|
|
|
When working through future chapters, I highly recommend starting in the editor and practicing your keyboard shortcuts.
|
|
|
|
Over time, sending code to the console in this way will become so natural that you won't even think about it.
|
2016-08-20 03:42:43 +08:00
|
|
|
|
|
|
|
## RStudio diagnostics
|
2016-08-19 03:51:47 +08:00
|
|
|
|
|
|
|
The script editor will also highlight syntax errors with a red squiggly line and a cross in the sidebar:
|
|
|
|
|
|
|
|
```{r echo = FALSE, out.width = NULL}
|
|
|
|
knitr::include_graphics("screenshots/rstudio-diagnostic.png")
|
|
|
|
```
|
|
|
|
|
|
|
|
Hover over the cross to see what the problem is:
|
|
|
|
|
|
|
|
```{r echo = FALSE, out.width = NULL}
|
|
|
|
knitr::include_graphics("screenshots/rstudio-diagnostic-tip.png")
|
|
|
|
```
|
|
|
|
|
|
|
|
RStudio will also let you know about potential problems:
|
|
|
|
|
|
|
|
```{r echo = FALSE, out.width = NULL}
|
|
|
|
knitr::include_graphics("screenshots/rstudio-diagnostic-warn.png")
|
|
|
|
```
|
|
|
|
|
2020-01-16 02:40:59 +08:00
|
|
|
## Exercises
|
2016-08-19 03:51:47 +08:00
|
|
|
|
2021-02-21 23:40:40 +08:00
|
|
|
1. Go to the RStudio Tips Twitter account, <https://twitter.com/rstudiotips> and find one tip that looks interesting.
|
|
|
|
Practice using it!
|
2016-08-19 03:51:47 +08:00
|
|
|
|
2021-02-21 23:40:40 +08:00
|
|
|
2. What other common mistakes will RStudio diagnostics report?
|
|
|
|
Read <https://support.rstudio.com/hc/en-us/articles/205753617-Code-Diagnostics> to find out.
|