r4ds/workflow-scripts.Rmd

62 lines
3.5 KiB
Plaintext
Raw Normal View History

2016-08-19 03:51:47 +08:00
# Workflow: scripts
2016-10-03 21:36:51 +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
```
2016-11-01 06:26:15 +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
2016-08-20 03:42:43 +08:00
## Running code
2016-08-19 03:51:47 +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))
```
2016-08-20 03:42:43 +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-10-04 05:08:44 +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
2016-10-03 21:36:51 +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")
```
## Exercises
2016-08-19 03:51:47 +08:00
1. Go to the RStudio Tips Twitter account, <https://twitter.com/rstudiotips>
2016-08-19 03:51:47 +08:00
and find one tip that looks interesting. Practice using it!
1. What other common mistakes will RStudio diagnostics report? Read
2016-08-19 03:51:47 +08:00
<https://support.rstudio.com/hc/en-us/articles/205753617-Code-Diagnostics> to
find out.