2022-05-14 04:46:49 +08:00
# Transform {#sec-transform-intro .unnumbered}
2021-03-04 01:13:14 +08:00
2022-05-14 04:46:49 +08:00
```{r}
#| results: "asis"
#| echo: false
source("_common.R")
```
2021-03-04 01:13:14 +08:00
2022-09-30 05:36:56 +08:00
After reading the first part of the book, you understand (at least superficially) the most important tools for doing data science.
2022-09-30 00:22:45 +08:00
Now it's time to start diving into the details.
2022-09-30 05:36:56 +08:00
In this part of the book, you'll learn about the most important types of variables that you'll encounter inside a data frame and learn the tools you can use to work with them.
2021-03-04 01:13:14 +08:00
2022-09-30 00:22:45 +08:00
```{r}
#| label: fig-ds-transform
#| echo: false
#| fig-cap: >
#| The options for data transformation depends heavily on the type of
#| data involve, the subject of this part of the book.
#| fig-alt: >
#| Our data science model transform, highlighted in blue.
#| out.width: NULL
knitr::include_graphics("diagrams/data-science/transform.png", dpi = 270)
```
2021-03-04 01:13:14 +08:00
2022-09-30 05:36:56 +08:00
You can read these chapters as you need them; they're designed to be largely standalone so that they can be read out of order.
2021-03-04 01:13:14 +08:00
2022-09-30 05:36:56 +08:00
- In @sec-tibbles, you'll learn about the **tibble**, the variant of the data frame that we use in this book.
You'll learn what makes tibbles different from regular data frames and how you can use them to hand enter data.
2021-03-04 01:13:14 +08:00
2022-09-30 00:22:45 +08:00
- @sec-logicals teaches you about logical vectors.
2022-09-30 05:36:56 +08:00
These are simplest type of vector, but are extremely powerful.
2022-09-30 00:22:45 +08:00
You'll learn how to create them with numeric comparisons, how to combine them with Boolean algebra, how to use them in summaries, and how to use them for condition transformations.
2021-03-29 21:58:27 +08:00
2022-09-30 00:22:45 +08:00
- @sec-numbers dives into tools for vectors of numbers, the powerhouse of data science.
2022-09-30 05:36:56 +08:00
You'll learn more about counting and a bunch of important transformation and summary functions.
2021-03-04 01:13:14 +08:00
2022-09-30 05:36:56 +08:00
- @sec-strings will give you the tools to work with strings: you'll slice them, you'll dice them, and you'll stick them back together again.
This chapter mostly focuses on the stringr package, but you'll also learn some more tidyr functions devoted to extracting data from strings.
2021-03-29 21:58:27 +08:00
2022-09-30 05:36:56 +08:00
- @sec-regular-expressions introduces you to regular expressions, a powerful tool for manipulating strings.
This chapter will take you from thinking that a cat walked over your keyboard to reading and writing complex string patterns.
2021-03-04 01:13:14 +08:00
2022-09-30 05:36:56 +08:00
- @sec-factors introduces factors: the data type that R uses to store categorical data.
You use a factor when variable has a fixed set of possible values, or when you want to use a non-alphabetical ordering of a string.
2021-03-04 01:13:14 +08:00
2022-09-29 23:49:03 +08:00
- @sec-dates-and-times will give you the key tools for working with dates and date-times.
2022-09-30 00:22:45 +08:00
Unfortunately, the more you learn about date-times, the more complicated they seem to get, but with the help of the lubridate package, you'll learn to how to overcome the most common challenges.
2022-09-30 05:36:56 +08:00
- We've discussed missing values a couple of times in isolation, but @sec-missing-values will cover them holistically, helping you come to grips with the difference between implicit and explicit missing values, and how and why you might convert between them.
2022-09-30 00:22:45 +08:00
2022-09-30 05:36:56 +08:00
- @sec-joins finishes up this part of the book by giving you tools to join two (or more) data frames together.
2022-09-30 00:22:45 +08:00
Learning about joins will force you to grapple with the idea of keys, and think about how you identify each row in a dataset.