forked from cienciadedatos/r4ds
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path29-rmarkdown-formats.qmd
274 lines (180 loc) · 14.2 KB
/
29-rmarkdown-formats.qmd
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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
# Formatos de R Markdown
## Introducción
Hasta ahora has visto R Markdown usado para producir documentos HTML. Este capítulo muestra una breve descripción de algunos de los muchos otros tipos de documentos que puedes generar con R Markdown. Hay dos maneras de definir el output de un documento:
1. De forma permanente, modificando el encabezado YAML:
```yaml
title: "Demo Viridis"
output: html_document
```
2. De forma transitoria, llamando `rmarkdown::render()` directamente:
```{r eval = FALSE}
rmarkdown::render("diamond-sizes.Rmd", output_format = "word_document")
```
Esto es útil si quieres producir múltiples tipos de outputs programáticamente.
El botón knit de RStudio genera un archivo con el primer tipo de formato listado en el campo`output`. Puedes generar archivos en formatos adicionales haciendo clic en el menú de selección al lado del botón knit.
```{r, echo = FALSE, out.width = NULL}
knitr::include_graphics("screenshots/rmarkdown-knit.png")
```
## Opciones de salida
Cada formato de salida está asociado con una función de R. Puedes escribir `foo` o `pkg::foo`. Si omites `pkg`, por defecto se asume que es rmarkdown. Es importante conocer el nombre de la función que genera el documento de salida, porque así es como obtienes ayuda. Por ejemplo, para saber qué parámetros puedes definir con `html_document`, busca en `?rmarkdown::html_document`.
Para sobrescribir los parámetros predeterminados necesitas usar un campo de `output` extendido. Por ejemplo, si quisieras generar un `html_document` con una tabla de contenido flotante, deberías usar:
```yaml
output:
html_document:
toc: true
toc_float: true
```
Incluso puedes generar múltiples salidas suministrando una lista de formatos:
```yaml
output:
html_document:
toc: true
toc_float: true
pdf_document: default
```
Nota la sintaxis especial si no quieres modificar ninguna de las opciones por defecto: debes agregar `default`.
## Documentos
El capítulo anterior se enfocó en en la salida por defecto, que es `html_document`. Sin embargo, hay un número de variaciones básicas para generar diferentes tipos de documentos:
* `pdf_document` crea un PDF con LaTeX (un sistema de código abierto
de composición de textos), que necesitarás instalar. RStudio te notificará
si no lo tienes.
* `word_document` para documentos de Microsoft Word (`.docx`).
* `odt_document` para documentos de texto OpenDocument (`.odt`).
* `rtf_document` para documentos de Formato de Texto Enriquecido (`.rtf`).
* `md_document` para documentos Markdown. Típicamente no es muy útil en sí mismo,
pero puedes usarlo si, por ejemplo, tu CMS corporativo o
tu wiki de laboratorio usa markdown.
* `github_document`: esta es una versión de `md_document` específicamente
diseñada para compartir en GitHub.
Recuerda que cuando generes un documento para compartirlo con responsables de la toma de decisiones, puedes desactivar la visualización predeterminada de código, definiendo las opciones globales en el fragmento de configuración (setup):
```{r, eval = FALSE}
knitr::opts_chunk$set(echo = FALSE)
```
Otra opción para los `html_document`es hacer que los fragmentos de código estén escondidos por defecto, pero visibles con un clic:
```yaml
output:
html_document:
code_folding: hide
```
## Notebooks
Un notebook `html_notebook` es una variación de un `html_document`. Los outputs de los dos documentos son muy similares, pero tienen propósitos distintos. Un `html_document` está enfocado en la comunicación con personas encargadas de la toma de decisiones, mientras que un notebook está enfocado en colaborar con otros/as científicos/as de datos. Estos propósitos diferentes llevan a que la salida HTML sea usada de diferentes maneras. Ambas contendrán todo el output renderizado, pero el notebook también contendrá el código fuente completo. Esto significa que puedes usar el archivo `.nb.html` generado por el notebook de dos maneras:
1. Puedes verlo en un navegador web y ver el output generado. A diferencia del
`html_document`, esta renderización siempre incluye una copia incrustada del
código fuente que lo generó.
2. Puedes editarlo en RStudio. Cuando abras un archivo `.nb.html`, RStudio
automáticamente recreará el archivo `.Rmd` que lo creó. En el futuro, también
podrás incluir archivos de soporte (por ej., archivos de datos `.csv`), que
serán extraídos automáticamente cuando sea necesario.
Enviar archivos `.nb.html` por correo electrónico es una manera simple de compartir los análisis con tus colegas. Pero las cosas se pondrán difíciles tan pronto como quieras hacer cambios. Si esto empieza a suceder, es un buen momento para aprender Git y GitHub. Aprender Git y Github definitivamente es doloroso al principio, pero la recompensa de la colaboración es enorme. Como se mencionó anteriormente, Git y GitHub están fuera del alcance de este libro, pero este es un consejo útil si ya los estás usando: usa las dos salidas, `html_notebook` y `github_document`:
```yaml
output:
html_notebook: default
github_document: default
```
`html_notebook` te da una vista previa local y un archivo que puedes compartir por correo electrónico. `github_document` crea un archivo md mínimo que puedes ingresar en Git. Puedes revisar fácilmente cómo los resultados de tus análisis (no solo el código) cambian con el tiempo y GitHub lo renderizará muy bien en línea.
## Presentaciones
También puedes usar R Markdown para crear presentaciones. Obtienes menos control visual que con herramientas como Keynote y PowerPoint, pero ahorrarás mucho tiempo insertando automáticamente los resultados de tu código R en una presentación. Las presentaciones funcionan dividiendo tu contenido en diapositivas, con una nueva diapositiva que comienza en cada encabezado de primer nivel (`#`) o de segundo nivel (`##`). También puedes insertar una regla horizontal (`***`) para crear una nueva diapositiva sin encabezado.
R Markdown viene con tres formatos de presentación integrados:
1. `ioslides_presentation` - Presentación HTML con ioslides.
2. `slidy_presentation` - Presentación HTML con W3C Slidy.
3. `beamer_presentation` - Presentación PDF con LaTeX Beamer.
Otros dos formatos populares son proporcionados por paquetes:
1. `revealjs::revealjs_presentation` - Presentación HTML con reveal.js.
Requiere el paquete __revealjs__.
2. __rmdshower__, <https://github.com/MangoTheCat/rmdshower>, proporciona un
wrapper para el motor de presentaciones __shower__, <https://github.com/shower/shower> .
## Dashboards
Los dashboards o tableros de control son una forma útil de comunicar grandes cantidades de información de forma visual y rápida. Flexdashboard hace que sea particularmente fácil crear dashboards usando R Markdown y proporciona una convención de cómo los encabezados afectan el diseño:
* Cada encabezado de Nivel 1 (`#`) comienza una nueva página en el dashboard.
* Cada encabezado de Nivel 2 (`##`) comienza una nueva columna.
* Cada encabezado de Nivel 3 (`###`) comienza una nueva fila.
Por ejemplo, puedes producir este dashboard:
```{r, echo = FALSE, out.width = "75%"}
knitr::include_graphics("screenshots/rmarkdown-flexdashboard.png")
```
Usando este código:
```{r comment = "", echo = FALSE}
cat(readr::read_file("rmarkdown/dashboard.Rmd"))
```
Flexdashboard también proporciona herramientas simples para crear barras laterales, tabuladores, cuadros de valores y medidores. Para obtener más información (en inglés) acerca de Flexdashboard visita <http://rmarkdown.rstudio.com/flexdashboard/>.
## Interactividad
Cualquier formato HTML (documento, notebook, presentación o dashboard) puede contener componentes interactivos.
### htmlwidgets
HTML es un formato interactivo y puedes aprovechar esa interactividad con __htmlwidgets__, que son funciones de R que producen visualizaciones HTML interactivas. Por ejemplo, fíjate en el mapa de __leaflet__ a continuación. Si estás viendo esta página en la web, puedes arrastrar el mapa, acercar y alejar, etc. Obviamente no puedes hacer esto en un libro, por lo que RMarkdown automáticamente inserta una captura de pantalla estática.
```{r}
library(leaflet)
leaflet() %>%
setView(174.764, -36.877, zoom = 16) %>%
addTiles() %>%
addMarkers(174.764, -36.877, popup = "Maungawhau")
```
Lo bueno de htmlwidgets es que no necesitas saber nada sobre HTML o JavaScript para usarlos. Todos los detalles están incluidos en el paquete, por lo que no tienes que preocuparte por eso.
Hay muchos paquetes que proporcionan htmlwidgets, incluyendo:
* __dygraphs__, <http://rstudio.github.io/dygraphs/>, para visualizaciones
interactivas de series de tiempo.
* __DT__, <http://rstudio.github.io/DT/>, para tablas interactivas.
* __threejs__, <https://github.com/bwlewis/rthreejs>, para plots 3D interactivos.
* __DiagrammeR__, <http://rich-iannone.github.io/DiagrammeR/>, para diagramas
(como diagramas de flujo y diagramas simples de nodos).
Para obtener más información sobre los htmlwidgets y ver una lista más completa de los paquetes que los proporcionan, visita <http://www.htmlwidgets.org/>.
### Shiny
Los htmlwidgets proporcionan interactividad del lado del cliente, es decir que toda la interactividad ocurre en el navegador, independientemente de R. Por un lado, esto es bueno porque puedes distribuir el archivo HTML sin ninguna conexión con R. Sin embargo, también limita fundamentalmente lo que puedes hacer a las cosas que han sido implementadas en HTML y JavaScript. Una alternativa es usar __shiny__, un paquete que te permite crear interactividad usando código R, no JavaScript.
Para llamar código Shiny desde un documento R Markdown, agrega `runtime: shiny` al encabezado:
```yaml
title: "Applicación Web Shiny"
output: html_document
runtime: shiny
```
Luego puedes usar las funciones de "input" para agregar componentes interactivos al documento:
```{r, eval = FALSE}
library(shiny)
textInput("nombre", "Cuál es tu nombre?")
numericInput("edad", "Cuántos años tienes?", NA, min = 0, max = 150)
```
```{r, echo = FALSE, out.width = NULL}
knitr::include_graphics("screenshots/rmarkdown-shiny.png")
```
Después puedes referirte a los valores con `input$nombre` e `input$edad` y el código que los usa se volverá a ejecutar automáticamente cada vez que los valores cambien.
No podemos mostrarte una aplicación Shiny corriendo ahora porque las interacciones de Shiny ocurren en el lado del servidor. Esto quiere decir que puedes escribir aplicaciones interactivas sin saber JavaScript, pero necesitas un servidor para correrlas. Esto introduce un problema logístico: Las aplicaciones Shiny necesitan un servidor para correr en línea. Cuando corres una aplicación Shiny en tu propia computadora, Shiny automáticamente crea un servidor Shiny para que la puedas correr, pero necesitarás un servidor Shiny público si quieres proporcionar este tipo de interactividad en línea. Ésta es la limitación fundamental de Shiny: puedes crear en Shiny todo lo que puedes crear en R, pero necesitarás que R esté corriendo en algún lugar.
Aprende más sobre Shiny en: <http://shiny.rstudio.com/>.
## Sitios Web
Con un poco más de infraestructura puedes usar R Markdown para crear un sitio web completo:
* Coloca todos tus archivos `.Rmd` en un mismo directorio. `index.Rmd` será tu
página de inicio.
* Agrega un archivo YAML llamado `_site.yml` que proporcionará la navegación para el sitio.
Por ejemplo:
```{r echo = FALSE, comment = ""}
cat(readr::read_file("rmarkdown/example-site.yml"))
```
Ejecuta `rmarkdown::render_site()` para crear `_site`, un directorio de archivos listo para ser implementado como un sitio web estático independiente, o si usas un proyecto de RStudio para el directorio de tu sitio web, RStudio agregará una pestaña de compilación que puedes usar para crear y obtener una vista previa de tu sitio.
Lee más acerca de sitios web en: <http://rmarkdown.rstudio.com/rmarkdown_websites.html>.
## Otros Formatos
Otros paquetes proveen incluso más formatos de salida:
* El paquete __bookdown__, <https://github.com/rstudio/bookdown>,
hace que crear libros, como este mismo, sea fácil. Para aprender más, lee
[_Authoring Books with R Markdown_](https://bookdown.org/yihui/bookdown/),
de Yihui Xie, el que, por supuesto, escrito en bookdown. Visita
<http://www.bookdown.org> para ver otros libros bookdown escritos
por la comunidad de R.
* El paquete __prettydoc__, <https://github.com/yixuan/prettydoc/>,
proporciona formatos livianos de documentos con una gama de temas atractivos.
* El paquete __rticles__, <https://github.com/rstudio/rticles>, compila una
selección de formatos específicos para revistas científicas.
Consulta <http://rmarkdown.rstudio.com/formats.html> para ver una lista de más formatos. También puedes crear tu propio formato siguiendo las instrucciones en inglés de: <http://rmarkdown.rstudio.com/developer_custom_formats.html>.
## Aprende más
Para obtener más información sobre comunicación efectiva con estos diferentes formatos, recomiendo los siguientes recursos (en inglés):
* Para mejorar tus habilidades de presentación, recomiendo: [_Presentation Patterns_](https://amzn.com/0321820800), de Neal Ford,
Matthew McCollough y Nathaniel Schutta. Proporciona un conjunto de patrones
efectivos (de alto y bajo nivel) que puedes usar para mejorar tus presentaciones.
* Si das charlas académicas, recomiendo que leas la guía para dar charlas del grupo Leek:
[_Leek group guide to giving talks_](https://github.com/jtleek/talkguide).
* Nosotros no lo hemos tomado, pero hemos escuchado buenos comentarios sobre
el curso en línea Public Speaking de Matt McGarrity:
<https://www.coursera.org/learn/public-speaking>.
* Si estás creando muchos dashboards, asegúrate de leer:
[Information Dashboard Design: The Effective Visual Communication of Data](https://amzn.com/0596100167). Te ayudará a crear dashboards realmente útiles
y no solo bonitos a la vista.
* Comunicar tus ideas efectivamente a menudo se beneficia de un poco
de conocimiento en diseño gráfico. El libro de diseño para no diseñadores,
[_The Non-Designer's Design Book_](http://amzn.com/0133966151),
es un buen lugar para empezar.