forked from rstudio/gt
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME.Rmd
108 lines (78 loc) · 4.4 KB
/
README.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
---
output: github_document
---
<!-- README.md is generated from README.Rmd. Please edit that file -->
```{r setup, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```
```{r packages, message=FALSE, warning=FALSE, include=FALSE}
library(gt)
library(tidyverse)
```
# gt <img src="man/figures/logo.svg" align="right" height="250px" />
[data:image/s3,"s3://crabby-images/3a6c6/3a6c640ea6a757151ca3b3ad7ed7dfe508a605be" alt="lifecycle"](https://www.tidyverse.org/lifecycle/#maturing)
[data:image/s3,"s3://crabby-images/1f44c/1f44cab8da60056eb8ec781da45caf4df7fadada" alt="CRAN status"](https://cran.r-project.org/package=gt)
[data:image/s3,"s3://crabby-images/74c78/74c78578eaec481cb0ceb2d50ba776d331c1b9c5" alt="Travis build status"](https://travis-ci.com/rstudio/gt)
[data:image/s3,"s3://crabby-images/6fe00/6fe00639dfbcebab595992c38445df72067794eb" alt="AppVeyor Build Status"](https://ci.appveyor.com/project/rstudio/gt)
[data:image/s3,"s3://crabby-images/b6dbe/b6dbec9d3de98a1f162306d946d8fce6d697e507" alt="Coverage status"](https://codecov.io/github/rstudio/gt?branch=master)
With the **gt** package, anyone can make wonderful-looking tables using the **R** programming language. The **gt** philosophy: we can construct a wide variety of useful tables with a cohesive set of table parts. These include the *table header*, the *stub*, the *stub head*, the *column labels*, the *table body*, and the *table footer*.
<p align="center"><img src="man/figures/gt_parts_of_a_table.svg" width="800px"></p>
It all begins with preprocessed **table data** (be it a tibble or a data frame). You decide how to compose your **gt table** with the elements you need for the task at hand. Output can either be in the form of **HTML**, **LaTeX**, or **RTF**. All work beautifully inside **R Markdown** documents.
<p align="center"><img src="man/figures/gt_workflow_diagram.svg" width="800px"></p>
The **gt** API is designed to be both straightforward yet powerful. The emphasis is on simple functions for the everyday display table needs. Here is a brief example of how to use **gt** to create an HTML **gt Table** from the included `sp500` dataset:
```r
library(gt)
library(tidyverse)
library(glue)
# Define the start and end dates for the data range
start_date <- "2010-06-07"
end_date <- "2010-06-14"
# Create a gt table based on preprocessed
# `sp500` table data
sp500 %>%
dplyr::filter(date >= start_date & date <= end_date) %>%
dplyr::select(-adj_close) %>%
dplyr::mutate(date = as.character(date)) %>%
gt() %>%
tab_header(
title = "S&P 500",
subtitle = glue::glue("{start_date} to {end_date}")
) %>%
fmt_date(
columns = vars(date),
date_style = 3
) %>%
fmt_currency(
columns = vars(open, high, low, close),
currency = "USD"
) %>%
fmt_number(
columns = vars(volume),
scale_by = 1 / 1E9,
pattern = "{x}B"
)
```
<p align="center"><img src="man/figures/gt_sp500_table.svg" width="800px"></p>
There are six datasets included in **gt**: `countrypops`, `sza`, `gtcars`, `sp500`, `pizzaplace`, and `exibble`. All of them are useful for experimenting with the API.
<p align="center"><img src="man/figures/gt_datasets.svg" width="800px"></p>
Beyond this simple example, there are many functions available in **gt** that make it possible to create highly customized tables.
<p align="center"><img src="man/figures/gt_functions.svg" width="100%"></p>
Want to try this out? First and foremost, the **gt** package is used in an R environment, so, if you don't have an R installation, it can be obtained from the [**Comprehensive R Archive Network (CRAN)**](https://cran.r-project.org/). For the best experience in working with R, use the [**RStudio Desktop IDE**](https://www.rstudio.com/products/rstudio/).
You can install the development version of **gt** from **GitHub**. Use the following in the R console to install **gt**.
```{r eval=FALSE}
install.packages("devtools")
remotes::install_github("rstudio/gt")
```
If you encounter a bug, have usage questions, or want to share ideas to make this package better, feel free to file an [issue](https://github.com/rstudio/gt/issues).
***
<img src="man/figures/gt_tables.png">
***
<h4 align="center">Code of Conduct</h4>
<h6 align="center">Please note that this project is released with a [Contributor Code of Conduct](CODE_OF_CONDUCT.md).<br>By participating in this project you agree to abide by its terms.</h6>
<h4 align="center">License</h4>
<h6 align="center">MIT © RStudio, Inc.</h6>