Uma
visão geral sobre o R Markdown
O
que é R Markdown?
R Markdown é uma linguagem de
marcação que combina o poder do R com a simplicidade
do Markdown. Essa ferramenta versátil foi desenvolvida para facilitar a
criação de documentos dinâmicos e reprodutíveis, integrando código,
texto e resultados em um único ambiente.
Um
pouco de história
O R Markdown teve suas origens no ecossistema do R, uma linguagem de programação estatística popular
entre cientistas de dados e pesquisadores. A ideia era criar um formato
de documento que permitisse a incorporação de análises de dados
diretamente no texto, facilitando a comunicação e a reprodução dos
resultados. O R Markdown é uma extensão do Markdown, que por sua vez foi
criado por John Gruber e Aaron Swartz em 2004.
Desenvolvimento do R Markdown
A criação do R Markdown é atribuída a Yihui Xie, um estatístico e
desenvolvedor chinês que contribuiu significativamente para a comunidade
R. Yihui Xie percebeu a necessidade de um formato de documento que fosse
mais flexível e permitisse a integração fluida de código R em documentos
de texto. Em 2012, ele lançou o pacote knitr
para o R, que facilitou a execução de código R incorporado em
documentos. O R Markdown surgiu como uma evolução natural desse
trabalho, proporcionando uma experiência mais simplificada e amigável
para os usuários.
Os objetivos principais por trás do R Markdown eram fornecer uma maneira
fácil e eficiente de combinar narrativas, código e resultados em um
único documento.
Benefícios do R Markdown
Algumas características e benefícios importantes incluem:
- Reprodutibilidade:
-
A capacidade de incorporar código diretamente no documento permite a
reprodução fácil e rápida dos resultados, garantindo a transparência e a
confiabilidade.
- Comunicação Efetiva:
-
Ao integrar análises de dados diretamente no texto, o R Markdown torna a
comunicação de resultados mais clara e compreensível, tornando a análise
de dados mais acessível para um público mais amplo.
- Flexibilidade:
-
Suporte para vários formatos de saída, como HTML, PDF, Word, entre
outros, proporciona flexibilidade na apresentação dos resultados.
Como criar o seu arquivo
Markdown
Para começar a utilizar o Markdown, você precisa ter algumas
ferramentas instaladas no seu ambiente de desenvolvimento. Aqui estão as
principais ferramentas que você precisa:
- R:
-
O R é uma linguagem de programação estatística amplamente
utilizada.
- RStudio:
-
Embora não seja estritamente necessário, o RStudio é um ambiente de
desenvolvimento integrado (IDE) muito popular para o R e é altamente
recomendado para trabalhar com R Markdown devido à sua integração
perfeita.
- Pandoc:
-
O Pandoc é uma ferramenta de conversão de documentos que o R Markdown
utiliza para converter documentos Markdown em vários formatos de saída,
como HTML, PDF, Word, etc. O RStudio instala
automaticamente o Pandoc. No entanto, se você não estiver
usando o RStudio ou precisar de uma versão mais recente do Pandoc, você
pode baixá-lo diretamente do site oficial.
Para começar, utilizaremos exclusivamente o R e o RStudio. Após a
instalação de ambos, você deve abrir o RStudio para iniciar o documento
RMarkdown.
Obs: Serão apresentadas aqui duas formas de como
você pode armazenar seu documento RMarkdown. O autor deste guia utiliza
e recomenda a segunda forma.
Segunda foma
Com o Rstudio aberto, você deve ir no canto superior esquerdo em
File > New Project....

Agora escolha a opção New Directory para iniciar um
projeto ne um novo diretório de
trabalho.

Escolha a opção New Project para criar um novo projeto
em um diretório vazio.

Coloque um nome no seu diretório. Após isso, vá no seu
Explorador de Arquivos e crie uma pasta para ser seu
subdiretório. Você pode utilizar um único subdiretório para armazenar
vários diretórios.

Volte para o Rstudio e vá na opção Browse... para
selecionar a pasta que você criou como subdiretório.

Lembre de deixar selecionado a opção
Use renv with this project para que seja utilizado um
caminho relativo.
Feito isso, basta ir em
Create Project para criar o seu
novo projeto.
Com o projeto criado, basta criar o arquivo Markdown. Você pode fazer
de duas formas: a primeira mostrada será a recomendada para quem está
começando ou para quem está querendo seguir este guia de RMarkdown à
risca, e a segunda forma é para quem já sabe um pouco de Markdown,
inclusive fazer uma cabeçalho YAML, o que será mostrado nos ultimos
capítulos deste guia.
Renderização do documento no RMarkdown
Para começar, escreva qualquer coisa que venha na sua mente abaixo do
cabeçalho YAML. Após isso aperte
Ctrl+Shift+k ou clique no botão
Knit para renderizar o documento, igual na seguinte imagem.
Cabeçalhos
Para inserir seções de diferentes níveis, vulgo cabeçalhos, você vai
utilizar a seguinte sintaxe
# Cabeçalho 1
## Cabeçalho 2
### Cabeçalho 3
#### Cabeçalho 4
##### Cabeçalho 5
###### Cabeçalho 6
Cabeçalho 1
Cabeçalho 2
Cabeçalho 3
Cabeçalho 4
Cabeçalho 5
Cabeçalho 6
Observe a relação entre os cabeçalhos: os de nível mais alto estão
aninhados dentro dos de nível mais baixo, desde que os de nível mais
alto sejam posicionados após os de nível mais baixos.
Opções de output para
cabeçalho
Sem numeração e não listado no
índice
O RMarkdown permite utilizar algumas opções que mudam o output do
cabeçalho. Nos cabeçalhos anteriores você deve ter percebido que não há
numeração e eles também não são colocados no índice. Para que isso
ocorra, use o seguinte código em que .unlisted tira o
cabeçalho do índice e .unnumbered tira a numeração.
#### Cabeçalho sem numeração e não listado no índice {.unlisted .unnumbered}
Cabeçalho sem numeração e não
listado no índice
Abas iterativas
Também é possível tranformar os cabeçalhos em abas iterativas a
partir da opção.tabset. Outra opção como
.tabset-fade permite deixar a transição entre as abas mais
suave. O exemplo a seguir ilustra esses comandos.
#### Seções com Abas {.tabset .tabset-fade .unlisted .unnumbered}
##### Aba 1 {.unlisted .unnumbered}
Este é o conteúdo da Aba 1.
##### Aba 2 {.unlisted .unnumbered}
Este é o conteúdo da Aba 2.
##### Aba 3 {.unlisted .unnumbered}
Este é o conteúdo da Aba 3.
Quebra de linha
Para fazer quebra de linha basta colocar dois espaços no final de um
texto ou adicionar uma barra invertida, de acordo com o seguinte
código.
Aqui vai ser realizado uma quebra de linha
Aqui também será feito uma quebra de linha\
Aqui vai ser realizado uma quebra de
linha
Aqui também será feito uma quebra de linha
Além disso, se você quer adicionar mais quebras de linhas, mas em
linhas sem nenhuma informação, é possível fazer o seguinte código
html.
Aqui será realizado ...\
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
... várias quebras de linha\
Aqui será realizado …
… várias quebras de
linha
Algumas opções de formatação de texto
| *itálico* |
itálico |
| _itálico_ |
itálico |
| *em*apenas*algumas*letras |
emapenasalgumasletras |
| **negrito** |
negrito |
| __negrito__ |
negrito |
| **em**apenas**algumas**letras |
emapenasalgumasletras |
| sobrescrito^2^ |
sobrescrito2 |
| subscrito~2~ |
subscrito2 |
| ~~sublinhado~~ |
sublinhado |
Bloco
de citação
Para adicionar um bloco de citação você utilizará a seguinte
syntax:
> Aqui você fará sua citação
> Veja que a quebra de linha não é automática
Aqui você fará sua citação Veja que a quebra de linha não é
automática
Traço, travessão e reta de separação
Para adicionar um traço e um travessão faça o seguinte:
| Traço: -- |
Traço: – |
| Travessão: --- |
Travessão: — |
Para adicionar uma reta horizontal de separação você pode utiizar
duas formas, veja:
Três estrelas ou mais:
***
Três traços ou mais:
---
Listas
Lista não ordenada
Há três formas de fazer uma lista não ordenada. Observe e pratique:
Primeira forma
- Lista não ordenada
- Item
- Item
- Item
Segunda forma
+ Lista não ordenada
+ Item
+ Item
+ Item
Terceira forma
* Lista não ordenada
* Item
* Item
* Item
Lista Ordenada
Você pode fazer listas ordenadas da seguinte forma.
1. Lista ordenada
1. Item
1. Item
2. Lista ordenada
1. Item
1. Item
2. Lista ordenada
- Item
* Item
- Lista não ordenada
+ Item
3. Ordenção automática sem funcionamento
- Lista ordenada
- Item
- Item
- Lista ordenada
- Item
- Item
- Lista ordenada
- Ordenção automática sem funcionamento
Links
Há três maneiras de adicionar links clicáveis no RMarkdown, ambas
interessantes para diferentes casos.
- Para fazer a primeira maneira realize o seguinte código.
Primeiro estilo de link: <https://linktr.ee/pet_estatisticaufc>
Primeiro estilo de link: https://linktr.ee/pet_estatisticaufc
- A segunda maneira deixa o link visualmente mais bonito,
observe:
Segundo estilo de link: [PET Estatística UFC](https://linktr.ee/pet_estatisticaufc "PET Estatística")
Segundo estilo de link: PET
Estatística UFC
- A terceira maneira é interessante para adicionar o mesmo link várias
vezes em diferentes palavras, veja:
Terceiro estilo de link: [PET Estatística UFC][Link-1]\
O Mesmo link com outro nome: [Programa de Educação Tutorial da Estatística][Link-1]
[Link-1]:https://linktr.ee/pet_estatisticaufc 'PET Estatística'
Terceiro estilo de link: PET
Estatística UFC
O Mesmo link com outro nome: Programa de Educação Tutorial da
Estatística
Imagens
Parecido com os links, as imagens podem ser adicionadas de três
formas.
- A primeira forma é a seguinte:
<div style="text-align:center">
{ width=20% }
</div>
Universidade Federal do Ceará
Observe que esses códigos com <div alguma-coisa>
são adicionais do html que você pode está utilizando. Então não se
preocupe se não entendê-los porque para entender markdown basta focar
nas outras partes.
- A segunda maneira, melhor para adicionar a mesma imagem várias vezes
ou para ter uma maior organização, é a seguinte:
![Universidade Federal do Ceará][link-2]
![Logo da UFC][link-2]
[link-2]:https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTyblZQAVU4rkTuEx-8wocoM7XxO2a31Nsu3L5Y3Guj0w&s 'Logo UFC'
Universidade Federal do Ceará
Logo da UFC
Notas de Rodapé
Utilize a seguinte syntax para adicionar uma nota de rodapé:
Isso é uma nota de rodapé: [^def]
[^def]: definição
Isso é uma nota de rodapé:
Note que não é necessário fazer a numeração das notas de rodapé
porque elas são numeradas automaticamente. Além disso, a nota de rodapé
é clicável, levando o usuário ao final do documento, onde se encontram
todas notas de rodapé.
Bibliográfia
Arquivo .bib
Para criar um arquivo .bib você deve
abrir um arquivo de texto. Para preenchê-lo você irá utilizar os dados
bibliográficos no formato BibTeX. É possível pegar esses dados já feitos
no Google
Acadêmico.
Por exemplo, digamos que você quer citar o livro Estatística Básica.
Basta você pesquisar o nome do livro e ir na opção
Citar.

Após isso, basta escolher a opção BibTeX.
Depois, é só copiar e colar no seu arquivo de texto. Você pode ir
adicionando essas referências a qualquer momento no seu arquivo de
texto, então já é possível salvá-lo dentro do seu diretório. Lembre de
salvar o seu arquivo com o “.bib” no final ao invés de “.txt”.

Com isso, no próximo tópico você irá aprender a como colocar o seu
arquvo .bib em funcionamento dentro do RMarkdown.
A
opção de bibliografia no YAML HEADER
Para colocar seu arquivo .bib em funcionamento basta adicionar
bibliography: Nome.bib em seu cabeçalho YAML. Veja o
seguinte exemplo com o arquivo criado na seção anterior:
---
title: "Novo_Arquivo"
author: "Jonas"
date: "2024-02-08"
bibliography: bibliografia.bib
output: html_document
---
Observe que apenas colocar essa opção no cabeçalho YAML não vai
adicionar suas citações ou referências ao arquivo. Além disso, é
importante observar se o arquivo .bib está no seu diretório de trabalho
para não haver erros.
Citações
Para fazer uma citação você vai utiizar o @. Por
exemplo, para citar o livro Estatística Básica, o qual já está no
arquivo .bib criado anteriormente, você vai pegar a primeira informação
na citação BibTeX e colocá-la após o @.

Após renderizar o seu arquivo você verá que além da citação
foi colocado automaticamente no final do output a referência da
citação.

Se você quiser uma citação entre parênteses basta colocar
colchetes no código anterior.

Caso você queira que apenas o ano apareça na citação, você
pode utilizar a syntax anterior com um - na frente do
@.

Citação clicável
Para que seja possível clicar na citação e ir direto para as
referências é possível colocar a opção link-citations: TRUE
no cabeçalho YAML.

Mudança de idioma
Além disso, você deve ter percebido que as citações estão em outra
língua. Adicione a opção lang: pt-br no cabeçalho YAML para
que fique no idioma do Brasil, semelhante ao seguinte exemplo.
---
title: "Novo_Arquivo"
author: "Jonas"
date: "*07 de janeiro, 2025*"
bibliography: bibliografia.bib
link-citations: TRUE
lang: pt-br
output: html_document
---
Referência sem citação
Se caso você quiser fazer apenas a referência sem precisar fazer a
citação ao longo do seu documento, então coloque a opção
notice.

Se forem várias referências, então você pode fazer a separação com
vírgulas.

Equações matemáticas
Você pode inserir equações matemáticas no RMarkdown da mesma maneira
que o faria no LaTeX. Se você não está familiarizado com esse formato,
recomendamos acessar o site do Overleaf para obter mais
detalhes. Abaixo estão dois exemplos que demonstram como adicionar
equações matemáticas em seu documento.
Equação em linha
Essa forma permite colocar uma equação matemática na mesma linha que
o seu texto. Você pode fazer isso utilizando a seguinte syntax.
Por exemplo, esta é a fórmula do desvio padrão:
Desvio Padrão: $\sqrt{\frac{\sum_{i=1}^{n}x_i^2-n\overline{x}^2}{n-1}}$
Desvio Padrão: \(\sqrt{\frac{\sum_{i=1}^{n}x_i^2-n\overline{x}^2}{n-1}}\)
Veja que a equação foi colocada junto ao texto normal em uma única
linha.
Equação em bloco
Esta forma de escrita não possibilita a inserção de texto normal na
mesma linha que a equação, no entanto, centraliza automaticamente a
equação e deixa ela maior, o que dá um maior destaque. A sua syntax é a
seguinte:
O seguinte exemplo faz uma equação em bloco na qual a variável
W tem distribuição normal padrão.
$$W = \frac{\displaystyle\sum_{i=1}^{n}X{i}-n\mu}{\sqrt{n}\sigma}$$
\[W =
\frac{\displaystyle\sum_{i=1}^{n}X{i}-n\mu}{\sqrt{n}\sigma}\]
Chunks
Chunks permitem que códigos de diferentes linguagens (como R, python,
SQL, LaTeX, entre outras) sejam adicionadas ao arquivo do RMarkdown, o
que permite reproduzir, por exemplo, tabelas, gráficos e cálculos dentro
do seu arquivo. Para adiconar um chunk que permite a reprodução de
código R realize o seguinte código.
```\{r\}
# Aqui dentro é onde irá ficar seu código R.
```
Uma observação a se fazer é que as barras invertidas que estam
aparecendo não fazem parte da sintaxe, foram apenas necessárias para
conseguir mostrar as chaves.
Para adicionar um chunk que reproduza qualquer linguagem, faça o
seguinte código substituindo nome pelo nome da línguagem de
interesse (python, r, bash, sql, php, etc).
```\{nome\}
Digite o seu código aqui.
```
Chunks oferecem opções que permitem mudar o output do código. Para
adicionar uma ou mais opções, faça o seguinte código.
```\{nome opcao1, opcao2, ..., opcaon\}
Digite o seu código aqui.
```
A seguir são apresentadas algumas das opções disponíveis no RMarkdown
para mudar o output do chunk.
| echo=FALSE |
Oculta o código, mostrando apenas o resultado. |
| message=FALSE |
Retira os avisos que aparecem no código. |
| eval=FALSE |
O código não é executado, mas será exibido no
documento. |
| include=FALSE |
Oculta o código e os resultados, mas executa o
código. |
| warning=FALSE |
Tira os avisos do output. |
| results=‘hide’ |
Oculta os resultados do código. |
| error=TRUE |
Renderiza o arquivo mesmo ocorrendo erros. |
| collapse=TRUE |
Junta todas as saídas de um chunk em um único
bloco. |
Para exemplificar a utilização de chunks com a linguagem r, a seguir
é feito um diagrama de disperção utilizando ggplot.
```\{r chunk-label, echo=TRUE, message=FALSE, warning=FALSE\}
library(tidyverse)
library(palmerpenguins)
library(ggthemes)
ggplot(data = penguins,
mapping = aes(x = flipper_length_mm, y = body_mass_g)
) +
geom_point(mapping = aes(color = species)) +
geom_smooth(method = 'lm')
```
library(tidyverse)
library(palmerpenguins)
library(ggthemes)
ggplot(data = penguins,
mapping = aes(x = flipper_length_mm, y = body_mass_g)
) +
geom_point(mapping = aes(color = species)) +
geom_smooth(method = 'lm')

Tambem é possível apresentar resultados numéricos dentro do seu
texto, como no seguinte exemplo.
A massa corporal média dos pinguins é `\r round(mean(penguins$body_mass_g, na.rm = T), 2)`
A massa corporal média dos pinguins é 4201.75
É importante ressaltar que a barra invertida não faz parte da
sintaxe, mas foi necessária para que todo o código seja mostrado.
Tabelas
Tabela feita na mão
Para fazer uma tabela sem a utilização do R diretamente no RMarkdown,
observe e execute o seguinte código.
|direita|esquerda|padrão|centralizado|
|---:|:---|---|:---:|
|12|12|12|12|
|123|123|123|123|
|2|2|2|2|
| 12 |
12 |
12 |
12 |
| 123 |
123 |
123 |
123 |
| 2 |
2 |
2 |
2 |
Veja que o caractere | é utilizado para delimitar o que
fica dentro de cada célula, alem da segunda linha do código ter traços e
pontos que dizem como vai ser o alinhamento do texto e delimita quem é
nome das colunas.
Referências
GRUBER, J. Markdown: Syntax. URL http://daringfireball.
net/projects/markdown/syntax. Retrieved on June, v. 24, p. 640,
2012.
XIE, Y. Dynamic Documents with R and knitr. [s.l.] CRC
Press, 2017.
XIE, Y.; ALLAIRE, J. J.; GROLEMUND, G. R markdown: The
definitive guide. [s.l.] CRC Press, 2018.
XIE, Y.; DERVIEUX, C.; RIEDERER, E. R markdown
cookbook. [s.l.] CRC Press, 2020.
---
title: |
  ::: {.floatting}

  ```{r out.width='18%', out.extra='style="float:left; padding:10px"', echo=FALSE}

  knitr::include_graphics("https://i.imgur.com/OxdHcLz.png")
  ```
  **Introdução ao Rmarkdown**
  :::
author: '*PET Estatística UFC*'
date: "`r format(Sys.Date(), '*%d de %B,  %Y*')`"
link-citations: true
bibliography: ref_intro_rmarkdown.bib
csl: "associacao-brasileira-de-normas-tecnicas.csl"
lang: "pt-br"
notice: |
  @gruber2012markdown, @xie2017dynamic, @xie2018r, @xie2020r
toc-title: |
  <div style="text-align:center">
  Introdução ao RMarkdown
  </div>
output:
  html_document:
    theme:
      bootswatch: superhero
    scss: _bootswatch (2).scss
    highlight: breezedark
    toc: true
    toc_float: true
    toc_depth: 2
    number_sections: true
    anchor_sections: true
    code_folding: show
    code_download: true
    fig_caption: true
    citation_package: biblatex
---

<br>

---

# Uma visão geral sobre o R Markdown
## O que é R Markdown?
R Markdown é uma <span style="color: violet;">linguagem de marcação</span>[^1] que combina o poder do R com a simplicidade do Markdown. Essa ferramenta versátil foi desenvolvida para facilitar a criação de documentos dinâmicos e reprodutíveis, integrando código, texto e resultados em um único ambiente.\

[^1]: Uma <span style="color: violet;">linguagem de marcação</span> é um conjunto de regras e convenções usadas para estruturar e formatar documentos de texto. Ela adiciona marcações ou tags ao texto para indicar como o documento deve ser apresentado ou estruturado quando renderizado ou processado. As linguagens de marcação são comumente usadas na criação de documentos, páginas web, e-mails e outros tipos de conteúdo textual.

## Um pouco de história
O R Markdown teve suas origens no ecossistema do R, uma <span style="color: violet;">linguagem de programação</span>[^2] estatística popular entre cientistas de dados e pesquisadores. A ideia era criar um formato de documento que permitisse a incorporação de análises de dados diretamente no texto, facilitando a comunicação e a reprodução dos resultados. O R Markdown é uma extensão do Markdown, que por sua vez foi criado por John Gruber e Aaron Swartz em 2004.\

[^2]: Uma <span style="color: violet;">linguagem de programação</span> é um conjunto de regras, símbolos e convenções usados para escrever instruções que um computador pode seguir para realizar uma tarefa específica. Ela serve como um meio de comunicação entre um programador e um computador, permitindo que o programador transmita suas intenções para a máquina de forma compreensível.

## Desenvolvimento do R Markdown
A criação do R Markdown é atribuída a Yihui Xie, um estatístico e desenvolvedor chinês que contribuiu significativamente para a comunidade R. Yihui Xie percebeu a necessidade de um formato de documento que fosse mais flexível e permitisse a integração fluida de código R em documentos de texto. Em 2012, ele lançou o pacote [knitr](https://yihui.org/knitr/ "knitr: 
Elegant, flexible, and fast dynamic report generation with R") para o R, que facilitou a execução de código R incorporado em documentos. O R Markdown surgiu como uma evolução natural desse trabalho, proporcionando uma experiência mais simplificada e amigável para os usuários.\
Os objetivos principais por trás do R Markdown eram fornecer uma maneira fácil e eficiente de combinar narrativas, código e resultados em um único documento. 

## Benefícios do R Markdown
Algumas características e benefícios importantes incluem:\

- Reprodutibilidade:
:   A capacidade de incorporar código diretamente no documento permite a reprodução fácil e rápida dos resultados, garantindo a transparência e a confiabilidade.\

* Comunicação Efetiva:
:   Ao integrar análises de dados diretamente no texto, o R Markdown torna a comunicação de resultados mais clara e compreensível, tornando a análise de dados mais acessível para um público mais amplo.\

+ Flexibilidade:
:   Suporte para vários formatos de saída, como HTML, PDF, Word, entre outros, proporciona flexibilidade na apresentação dos resultados.\


# Como criar o seu arquivo Markdown {.tabset .tabset-fade}
Para começar a utilizar o Markdown, você precisa ter algumas ferramentas instaladas no seu ambiente de desenvolvimento. Aqui estão as principais ferramentas que você precisa:\

- [R](https://www.r-project.org/ "The R Project for Statistical Computing"):
:   O R é uma linguagem de programação estatística amplamente utilizada.\

* [RStudio](https://www.rstudio.com/products/rstudio/download/ "RStudio Desktop"):
:   Embora não seja estritamente necessário, o RStudio é um ambiente de desenvolvimento integrado (IDE) muito popular para o R e é altamente recomendado para trabalhar com R Markdown devido à sua integração perfeita.\

- [Pandoc](https://pandoc.org/installing.html "Pandoc   a universal document converter"):
:   O Pandoc é uma ferramenta de conversão de documentos que o R Markdown utiliza para converter documentos Markdown em vários formatos de saída, como HTML, PDF, Word, etc. O RStudio **instala automaticamente** o Pandoc. No entanto, se você não estiver usando o RStudio ou precisar de uma versão mais recente do Pandoc, você pode baixá-lo diretamente do site oficial.\

Para começar, utilizaremos exclusivamente o R e o RStudio. Após a instalação de ambos, você deve abrir o RStudio para iniciar o documento RMarkdown.\

<br>

**Obs:** Serão apresentadas aqui duas formas de como você pode armazenar seu documento RMarkdown. O autor deste guia utiliza e recomenda a segunda forma.

## Primeira forma


Com o Rstudio aberto, você deve ir no canto superior esquerdo em `File` > `New File` > `R Markdown`.\
![](https://i.imgur.com/2BH3QVT.png "Criação de Novo Arquivo")\

<br>
<br>

Após isso você deve informar o `título` do seu documento, o `seu nome` e o `formato de saída` (é possível, após a criação do arquivo, mudar o formato de saída).\
![](https://i.imgur.com/H63bGQz.png "Especificação de algumas informações para o cabeçalho YAML")\
<br>
<br>

Com o arquivo criado sua tela aparecerá mais ou menos da seguinte forma. Não se assuste com esse script gerado pelo próprio RMarkdown, os seus elementos serão explicados em breve.\
![](https://i.imgur.com/SgWMBDd.png "Arquivo criado")\
<br>
<br>

Você pode apagar tudo que está abaixo do cabeçalho YAML, o qual é delimitado por três traços `---`. Observe, também, que abaixo do arquivo RMarkdown tem uma outra janela chamada console. Com essa janela é possível utilizar códigos do R para fazer diversas coisas, inclusive baixar pacotes necessários ao funcionamento do rmarkdown.\
![](https://i.imgur.com/iKsCKJI.png "Arquivo apenas com o cabeçalho YAML")\
<br>
<br>

Antes de começar, é preciso entender como guardar, da forma correta, o arquivo criado. Para isso, crie uma pasta no explorador de arquivos, ela será a pasta dos seus projetos de RMarkdown. Dentro dessa pasta, crie outra pasta que conterá o seu arquivo RMarkdown e outros arquivos necessários ao funcionamento do RMarkdown que futuramente você precisará guardar. Com isso feito, volte para o Rstudio, clique `Ctrl`+`Alt`+`S` e escolha a pasta que você criou.\
Com a pasta criada, agora é preciso defini-la como o seu <span style="color: violet;">diretório de trabalho</span>[^3] a ser utilizado. Você pode verificar o diretório de trabalho atual no console (na parte inferior esquerda é possível ver onde é o console) do rstudio usando a função getwd() e alterá-lo para a pasta mais interna que você criou usando a função setwd(). Por exemplo:
```{r collapse=TRUE}
getwd() # Retorna o diretório de trabalho sendo utilizado

#setwd("C:/Users/Administrator/Documents/PET_Projetos/PET_RMardown") # Altera o diretório de trabaho

# Obseve as barras de separação do caminho em setwd() 
# Quando você copia um caminho no windows, esse caminho é colocado com uma barra diferente (\)
```
<br>
<br>

## Segunda foma {.tabset .tabset-fade}

Com o Rstudio aberto, você deve ir no canto superior esquerdo em `File` > `New Project...`.\
![](Imagens/criar_projeto.png)\
<br>
<br>

Agora escolha a opção `New Directory` para iniciar um projeto ne um novo <span style="color: violet;">diretório de trabalho</span>[^3].\
![](Imagens/criar_projeto_new_directory.png)\

<br>
<br>

Escolha a opção `New Project` para criar um novo projeto em um diretório vazio.\
![](Imagens/criar_projeto_new_project.png)\

<br>
<br>

Coloque um nome no seu diretório. Após isso, vá no seu `Explorador de Arquivos` e crie uma pasta para ser seu subdiretório. Você pode utilizar um único subdiretório para armazenar vários diretórios.\
![](Imagens/create_new_project.png)\

<br>
<br>

Volte para o Rstudio e vá na opção `Browse...` para selecionar a pasta que você criou como subdiretório.\
![](Imagens/criar_projeto_subdiretorio.png)\

<br>
<br>

Lembre de deixar selecionado a opção `Use renv with this project` para que seja utilizado um **caminho relativo**.\
<div style="text-align:center">
![](Imagens/caminho_relativo.png)\
</div>

<br>
<br>

Feito isso, basta ir em `Create Project` para criar o seu novo projeto.\
<div style="text-align:center">
![](Imagens/create_project.png)\
</div>

<br>
<br>

Com o projeto criado, basta criar o arquivo Markdown. Você pode fazer de duas formas: a primeira mostrada será a recomendada para quem está começando ou para quem está querendo seguir este guia de RMarkdown à risca, e a segunda forma é para quem já sabe um pouco de Markdown, inclusive fazer uma cabeçalho YAML, o que será mostrado nos ultimos capítulos deste guia.

### Primeira forma de criar o arquivo RMarkdown
Para a primeira forma, vá em `File` > `New File` > `R Markdown...`.\
![](Imagens/new_rmarkdown_file.png)\

<br>
<br>
Após isso você deve informar o `título` do seu documento, o `seu nome` e o `formato de saída` (é possível, após a criação do arquivo, mudar o formato de saída).\
![](Imagens/criar_rmarkdowns.png)\

<br>
<br>

Com o arquivo criado, sua tela aparecerá mais ou menos da seguinte forma. Não se assuste com esse script gerado pelo pelo próprio RMarkdown, os seus elementos serão explicados em breve.\
![](Imagens/tela_apos_criacao.png)\

<br>
<br>

Você pode apagar tudo que está abaixo do cabeçalho YAML, o qual é delimitado por três traços `---`. Observe, também, que abaixo do arquivo do RMarkdown tem uma outra janela chamada console. Com essa janela é possível utilizar códigos do R para fazer diversas coisas, inclusive baixar pacotes necessários ao funcionamento do rmarkdown.\
![](Imagens/ambiente.png)\

Observe que você criou o seu arquivo RMarkdown mas não o salvou em seu diretório de trabalho. Você pode apertar `Ctrl` + `S` para salvar ou apertar `Ctrl` + `Shift` + `K` que, embora sirva para renderizar o seu arquivo, também o salva automaticamente.Você deve selecionar o seu diretório de trabaho, aquele dentro do subdiretório, para salvar o seu arquivo.\

<br>
<br>

Após esses passos você pode iniciar com o pé direito na parte da [syntax](#syntax) do RMarkdown. Aproveite!

### Segunda forma de criar o seu arquivo

A segunda forma de criar seu arquivo RMarkdown faz um Script em branco, sem aquele gerado automaticamente pelo próprio RMarkdown. Dessa forma, você cria tudo do zero, inclusive o cabeçalho YAML. Para fazê-lo, vá em `New Blank File` > `R Markdown...` e digite um nome para o seu arquivo.\
![](Imagens/arquivo_markdown.png)\

<br>
<br>

Ao criar seu arquivo você poderá vê-lo na aba `Files` no canto inferior direito. Além disso, se for pedido a instalação de algum pacote para o correto funcionamento do RMarkdown então aperte em `Install`.\
![](Imagens/inicio_markdown.png)\


Após esses passos você pode iniciar com o pé direito na parte da sintaxe do RMarkdown. Aproveite!

[^3]: O <span style="color: violet;">diretório de trabalho</span> no R é o local no sistema de arquivos onde o R procura por arquivos e onde ele salva novos arquivos por padrão, a menos que um caminho seja especificado. Quando você inicia uma sessão do R, o diretório de trabalho padrão é definido como o diretório em que o R foi iniciado. Isso significa que qualquer arquivo que você carrega ou salva sem especificar um caminho será relativo a esse diretório.


# Renderização do documento no RMarkdown
Para começar, escreva qualquer coisa que venha na sua mente abaixo do cabeçalho YAML. Após isso aperte `Ctrl`+`Shift`+`k` ou clique no botão `Knit` para renderizar o documento, igual na seguinte imagem.
![](https://i.imgur.com/ykdkiJp.png Rendenrização do RMarkdown)
<br>
<br>

# Cabeçalhos

Para inserir seções de diferentes níveis, vulgo cabeçalhos, você vai utilizar a seguinte sintaxe\

``` Markdown
# Cabeçalho 1
## Cabeçalho 2
### Cabeçalho 3
#### Cabeçalho 4
##### Cabeçalho 5
###### Cabeçalho 6
```
<span style="color: grey;">

# Cabeçalho 1 {.unlisted .unnumbered}
## Cabeçalho 2 {.unlisted .unnumbered}
### Cabeçalho 3 {.unlisted .unnumbered}
#### Cabeçalho 4 {.unlisted .unnumbered}
##### Cabeçalho 5 {.unlisted .unnumbered}
###### Cabeçalho 6 {.unlisted .unnumbered}

</span>

Observe a relação entre os cabeçalhos: os de nível mais alto estão aninhados dentro dos de nível mais baixo, desde que os de nível mais alto sejam posicionados após os de nível mais baixos.\

## Opções de output para cabeçalho {.tabset .unlisted .unnumbered}

### Sem numeração e não listado no índice {.unlisted .unnumbered}

O RMarkdown permite utilizar algumas opções que mudam o output do cabeçalho. Nos cabeçalhos anteriores você deve ter percebido que não há numeração e eles também não são colocados no índice. Para que isso ocorra, use o seguinte código em que `.unlisted` tira o cabeçalho do índice e `.unnumbered` tira a numeração.
``` Markdown
#### Cabeçalho sem numeração e não listado no índice {.unlisted .unnumbered}
```
#### Cabeçalho sem numeração e não listado no índice {.unlisted .unnumbered}

### Abas iterativas {.unlisted .unnumbered}
Também é possível tranformar os cabeçalhos em abas iterativas a partir da opção`.tabset`. Outra opção como `.tabset-fade` permite deixar a transição entre as abas mais suave. O exemplo a seguir ilustra esses comandos.

```
#### Seções com Abas {.tabset .tabset-fade .unlisted .unnumbered}

##### Aba 1 {.unlisted .unnumbered}
Este é o conteúdo da Aba 1.

##### Aba 2 {.unlisted .unnumbered}
Este é o conteúdo da Aba 2.

##### Aba 3 {.unlisted .unnumbered}
Este é o conteúdo da Aba 3.
```

#### Seções com Abas {.tabset .tabset-fade .unlisted .unnumbered}

##### Aba 1 {.unlisted .unnumbered}
Este é o conteúdo da Aba 1.

##### Aba 2 {.unlisted .unnumbered}
Este é o conteúdo da Aba 2.

##### Aba 3 {.unlisted .unnumbered}
Este é o conteúdo da Aba 3.


# Quebra de linha
Para fazer quebra de linha basta colocar dois espaços no final de um texto ou adicionar uma barra invertida, de acordo com o seguinte código.
``` markdown
Aqui vai ser realizado uma quebra de linha  
Aqui também será feito uma quebra de linha\
```
<span style="color: grey;">
Aqui vai ser realizado uma quebra de linha  
Aqui também será feito uma quebra de linha\
</span>

Além disso, se você quer adicionar mais quebras de linhas, mas em linhas sem nenhuma informação, é possível fazer o seguinte código html.
``` html
Aqui será realizado ...\
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
... várias quebras de linha\
```
<span style="color: grey;">
Aqui será realizado ...\
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
... várias quebras de linha\
</span>

# Algumas opções de formatação de texto

|Código|Saída|
|:---:|:---:|
|\*itálico\*|*itálico*|
|\_itálico\_|_itálico_|
|\*em\*apenas\*algumas\*letras|*em*apenas*algumas*letras|
|\*\*negrito\*\*|**negrito**|
|\_\_negrito\_\_|__negrito__|
|\*\*em\*\*apenas\*\*algumas\*\*letras|**em**apenas**algumas**letras|
|sobrescrito\^2\^|sobrescrito^2^|
|subscrito\~2\~|subscrito~2~|
|\~\~sublinhado\~\~|~~sublinhado~~|

# Como deixar o código de forma literal {.tabset .tabset-fade}
## Para um caractere
Para fazer isso em um caractere basta usar a barra invertida (\\), veja só:
``` markdown
**negrito**\
\*\*negrito\*\*
```

<span style="color: grey;">
**negrito**\
\*\*negrito\*\*\
</span>

## Para várias palavras em uma linha
Para várias palavras você utiliza crases:
``` Markdown
`Código de forma literal`

```

<span style="color: grey;">
`Código de forma literal`
</span>

## Para várias linhas:
Para utilizar código literal em várias linhas você pode usar três crases juntas `````` ``` ``````:

`````````markdown
```
Várias
linhas
de
código
literal
```
`````````

<span style="color: grey;">
```
Várias
linhas
de
código
literal
```
</span>

# Bloco de citação
Para adicionar um bloco de citação você utilizará a seguinte syntax:
```Markdown
> Aqui você fará sua citação
> Veja que a quebra de linha não é automática
```
> Aqui você fará sua citação
> Veja que a quebra de linha não é automática

# Traço, travessão e reta de separação
Para adicionar um traço e um travessão faça o seguinte:

|Código|Saída|
|:---:|:---:|
|Traço: \-\-|Traço: --|
|Travessão: \-\-\-|Travessão: ---|

Para adicionar uma reta horizontal de separação você pode utiizar duas formas, veja:\

Três estrelas ou mais:

`***`\

***

Três traços ou mais:

`---`

---

# Listas {.tabset .tabset-fade}
## Lista não ordenada
Há três formas de fazer uma lista não ordenada. Observe e pratique:
<br>

**Primeira forma**
``` markdown
- Lista não ordenada
  - Item
    - Item
      - Item
```

<span style="color: grey;">

- Lista não ordenada
  - Item
    - Item
      - Item

</span>

<br>

**Segunda forma**
``` markdown
+ Lista não ordenada
  + Item
    + Item
      + Item
```

<span style="color: grey;">

+ Lista não ordenada
  + Item
    + Item
      + Item

</span>

<br>

**Terceira forma**
``` markdown
* Lista não ordenada
  * Item
    * Item
      * Item
```

<span style="color: grey;">

* Lista não ordenada
  * Item
    * Item
      * Item

</span>
      
## Lista Ordenada
Você pode fazer listas ordenadas da seguinte forma.

``` Markdown
1. Lista ordenada
    1. Item
    1. Item
2. Lista ordenada
    1. Item
        1. Item
2. Lista ordenada
    - Item
      * Item
- Lista não ordenada
    + Item
3. Ordenção automática sem funcionamento

```

<span style="color: grey;">

1. Lista ordenada
    1. Item
    1. Item
2. Lista ordenada
    1. Item
        1. Item
2. Lista ordenada
    - Item
      * Item
- Lista não ordenada
    + Item
3. Ordenção automática sem funcionamento

</span>

## Lista com opções de marcação
Você pode fazer listas com opção de marcar junto ao que foi mostrado de listas não ordenadas e ordenadas, olhe só:

``` Markdown
- [x] Primeira opção
  * [ ] Item
  + [x] Item
    1. [ ] Item
    2. [ ] Item
    - [ ] Item
    * [ ] Item
    + [ ] Item

- [ ] Segunda opção
  * [x] Item
    + [ ] Item
      1. [ ] Item
      1. [ ] Item
      1. [ ] Item
    
- [x] Terceira opção
```

<span style="color: grey;">

- [x] Primeira opção
  * [ ] Item
  + [x] Item
    1. [ ] Item
    2. [ ] Item
    - [ ] Item
    * [ ] Item
    + [ ] Item

- [ ] Segunda opção
  * [x] Item
    + [ ] Item
      1. [ ] Item
      1. [ ] Item
      1. [ ] Item
    
- [x] Terceira opção

</span>


# Links
Há três maneiras de adicionar links clicáveis no RMarkdown, ambas interessantes para diferentes casos. 

<br>

* Para fazer a primeira maneira realize o seguinte código.\

``` markdown
Primeiro estilo de link: <https://linktr.ee/pet_estatisticaufc>
```
Primeiro estilo de link: <https://linktr.ee/pet_estatisticaufc>\

<br>

* A segunda maneira deixa o link visualmente mais bonito, observe:\

``` markdown
Segundo estilo de link: [PET Estatística UFC](https://linktr.ee/pet_estatisticaufc "PET Estatística")
```

Segundo estilo de link: [PET Estatística UFC](https://linktr.ee/pet_estatisticaufc "PET Estatística")\

<br>

* A terceira maneira é interessante para adicionar o mesmo link várias vezes em diferentes palavras, veja:\

``` markdown
Terceiro estilo de link: [PET Estatística UFC][Link-1]\
O Mesmo link com outro nome: [Programa de Educação Tutorial da Estatística][Link-1]

[Link-1]:https://linktr.ee/pet_estatisticaufc 'PET Estatística'
```

Terceiro estilo de link: [PET Estatística UFC][Link-1]\
O Mesmo link com outro nome: [Programa de Educação Tutorial da Estatística][Link-1]

[Link-1]:https://linktr.ee/pet_estatisticaufc 'PET Estatística'

# Imagens
Parecido com os links, as imagens podem ser adicionadas de três formas.\

<br>

* A primeira forma é a seguinte:

``` markdown
<div style="text-align:center">
![Universidade Federal do Ceará](https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTyblZQAVU4rkTuEx-8wocoM7XxO2a31Nsu3L5Y3Guj0w&s 'Logo UFC'){ width=20% }
</div>
```
<div style="text-align:center">
![Universidade Federal do Ceará](https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTyblZQAVU4rkTuEx-8wocoM7XxO2a31Nsu3L5Y3Guj0w&s 'Logo UFC'){ width=20% }
</div>

Observe que esses códigos com `<div alguma-coisa>` são adicionais do html que você pode está utilizando. Então não se preocupe se não entendê-los porque para entender markdown basta focar nas outras partes.

<br>

* A segunda maneira, melhor para adicionar a mesma imagem várias vezes ou para ter uma maior organização, é a seguinte:

``` markdown
![Universidade Federal do Ceará][link-2]

![Logo da UFC][link-2]

[link-2]:https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTyblZQAVU4rkTuEx-8wocoM7XxO2a31Nsu3L5Y3Guj0w&s 'Logo UFC'
```

![Universidade Federal do Ceará][link-2]

![Logo da UFC][link-2]

[link-2]:https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTyblZQAVU4rkTuEx-8wocoM7XxO2a31Nsu3L5Y3Guj0w&s 'Logo UFC'

# Notas de Rodapé
Utilize a seguinte syntax para adicionar uma nota de rodapé:\
```SQL
Isso é uma nota de rodapé: [^def]

[^def]: definição
```
<span style="color: grey;">
Isso é uma nota de rodapé: [^def]
</span>


[^def]: definição  

Note que não é necessário fazer a numeração das notas de rodapé porque elas são numeradas automaticamente. Além disso, a nota de rodapé é clicável, levando o usuário ao final do documento, onde se encontram todas notas de rodapé.\

# Bibliográfia {.tabset .tabset-fade}
## Arquivo .bib
Para criar um <span style="color: violet;">arquivo .bib</span>[^bib] você deve abrir um arquivo de texto. Para preenchê-lo você irá utilizar os dados bibliográficos no formato BibTeX. É possível pegar esses dados já feitos no [Google Acadêmico](https://scholar.google.com.br/?hl=pt).\

Por exemplo, digamos que você quer citar o livro Estatística Básica. Basta você pesquisar o nome do livro e ir na opção `Citar`.\
![](Imagens/google_academico.png)\

<br>
<br>

Após isso, basta escolher a opção BibTeX.\
<div style="text-align:center">
![](Imagens/google_academico2.png)\
</div>

<br>
<br>

Depois, é só copiar e colar no seu arquivo de texto. Você pode ir adicionando essas referências a qualquer momento no seu arquivo de texto, então já é possível salvá-lo dentro do seu diretório. Lembre de salvar o seu arquivo com o ".bib" no final ao invés de ".txt".\
![](Imagens/bib.png)\

Com isso, no próximo tópico você irá aprender a como colocar o seu arquvo .bib em funcionamento dentro do RMarkdown.\

[^bib]: Um <span style="color: violet;">arquivo .bib</span> é um arquivo de banco de dados bibliográfico usado comumente com o software de gerenciamento de referências bibliográficas, como BibTeX. Esse tipo de arquivo é frequentemente utilizado em trabalhos acadêmicos, como teses, dissertações, artigos de revistas e outros documentos que requerem citações e referências bibliográficas. O formato .bib geralmente contém informações bibliográficas sobre obras, como livros, artigos de periódicos, conferências, entre outros. Essas informações incluem detalhes como autor(es), título, ano de publicação, editora, número de páginas, ISSN ou ISBN, e outras informações relevantes.

## A opção de bibliografia no YAML HEADER {#bib}
Para colocar seu arquivo .bib em funcionamento basta adicionar `bibliography: Nome.bib` em seu cabeçalho YAML. Veja o seguinte exemplo com o arquivo criado na seção anterior:\
```Markdown
---
title: "Novo_Arquivo"
author: "Jonas"
date: "2024-02-08"
bibliography: bibliografia.bib
output: html_document
---

```
Observe que apenas colocar essa opção no cabeçalho YAML não vai adicionar suas citações ou referências ao arquivo. Além disso, é importante observar se o arquivo .bib está no seu diretório de trabalho para não haver erros.

## Citações
Para fazer uma citação você vai utiizar o `@`. Por exemplo, para citar o livro Estatística Básica, o qual já está no arquivo .bib criado anteriormente, você vai pegar a primeira informação na citação BibTeX e colocá-la após o `@`.\
![](Imagens/citacao.png)\
<br>
<br>
Após renderizar o seu arquivo você verá que além da citação foi colocado automaticamente no final do output a referência da citação.\
![](Imagens/output_citacao2.png)\
<br>
<br>
Se você quiser uma citação entre parênteses basta colocar colchetes no código anterior.\
![](Imagens/citacao2.png)\
<br>
<br>
Caso você queira que apenas o ano apareça na citação, você pode utilizar a syntax anterior com um `-` na frente do `@`.\
![](Imagens/citacao3.png)\

### Citação clicável
Para que seja possível clicar na citação e ir direto para as referências é possível colocar a opção `link-citations: TRUE` no cabeçalho YAML.\
![](Imagens/link-citation.png)\

### Mudança de idioma
Além disso, você deve ter percebido que as citações estão em outra língua. Adicione a opção `lang: pt-br` no cabeçalho YAML para que fique no idioma do Brasil, semelhante ao seguinte exemplo.\
```Markdown
---
title: "Novo_Arquivo"
author: "Jonas"
date: "`r format(Sys.Date(), '*%d de %B,  %Y*')`"
bibliography: bibliografia.bib
link-citations: TRUE
lang: pt-br
output: html_document
---

```

### Referência sem citação

Se caso você quiser fazer apenas a referência sem precisar fazer a citação ao longo do seu documento, então coloque a opção `notice`.\

![](Imagens/apenas_ref.png)\

Se forem várias referências, então você pode fazer a separação com vírgulas.\
![](Imagens/apenas_ref2.png)\


# Equações matemáticas {.tabset .tabset-fade}
Você pode inserir equações matemáticas no RMarkdown da mesma maneira que o faria no LaTeX. Se você não está familiarizado com esse formato, recomendamos acessar o [site do Overleaf](https://www.overleaf.com/learn/latex/Mathematical_expressions "Mathematical expressions") para obter mais detalhes. Abaixo estão dois exemplos que demonstram como adicionar equações matemáticas em seu documento.

## Equação em linha
Essa forma permite colocar uma equação matemática na mesma linha que o seu texto. Você pode fazer isso utilizando a seguinte syntax.
```Latex
$SuaEquação$
```

Por exemplo, esta é a fórmula do desvio padrão:
```Latex
Desvio Padrão: $\sqrt{\frac{\sum_{i=1}^{n}x_i^2-n\overline{x}^2}{n-1}}$
```
<span style="color: grey;">
Desvio Padrão: $\sqrt{\frac{\sum_{i=1}^{n}x_i^2-n\overline{x}^2}{n-1}}$\
</span>

Veja que a equação foi colocada junto ao texto normal em uma única linha.


## Equação em bloco
Esta forma de escrita não possibilita a inserção de texto normal na mesma linha que a equação, no entanto, centraliza automaticamente a equação e deixa ela maior, o que dá um maior destaque. A sua syntax é a seguinte:
```Latex
$$SuaEquação$$
```

O seguinte exemplo faz uma equação em bloco na qual a variável **W** tem distribuição normal padrão.
```Latex
$$W = \frac{\displaystyle\sum_{i=1}^{n}X{i}-n\mu}{\sqrt{n}\sigma}$$
```
<span style="color: grey;">
$$W = \frac{\displaystyle\sum_{i=1}^{n}X{i}-n\mu}{\sqrt{n}\sigma}$$
</span>

# Chunks
Chunks permitem que códigos de diferentes linguagens (como R, python, SQL, LaTeX, entre outras) sejam adicionadas ao arquivo do RMarkdown, o que permite reproduzir, por exemplo, tabelas, gráficos e cálculos dentro do seu arquivo. Para adiconar um chunk que permite a reprodução de código R realize o seguinte código.\

````````````Markdown
```\{r\}
# Aqui dentro é onde irá ficar seu código R.
```
````````````

Uma observação a se fazer é que as barras invertidas que estam aparecendo não fazem parte da sintaxe, foram apenas necessárias para conseguir mostrar as chaves.\

Para adicionar um chunk que reproduza qualquer linguagem, faça o seguinte código substituindo `nome` pelo nome da línguagem de interesse (python, r, bash, sql, php, etc).

````````````Markdown
```\{nome\}
Digite o seu código aqui.
```
````````````
Chunks oferecem opções que permitem mudar o output do código. Para adicionar uma ou mais opções, faça o seguinte código.

````````````Markdown
```\{nome opcao1, opcao2, ..., opcaon\}
Digite o seu código aqui.
```
````````````
A seguir são apresentadas algumas das opções disponíveis no RMarkdown para mudar o output do chunk.\

|Opção|O que ela faz|
|:---:|:---|
|echo=FALSE|Oculta o código, mostrando apenas o resultado.|
|message=FALSE|Retira os avisos que aparecem no código.|
|eval=FALSE|O código não é executado, mas será exibido no documento.|
|include=FALSE|Oculta o código e os resultados, mas executa o código.|
|warning=FALSE|Tira os avisos do output.|
|results='hide'|Oculta os resultados do código.|
|error=TRUE|Renderiza o arquivo mesmo ocorrendo erros.|
|collapse=TRUE|Junta todas as saídas de um chunk em um único bloco.|

Para exemplificar a utilização de chunks com a linguagem r, a seguir é feito um diagrama de disperção utilizando ggplot.
````````````Markdown
```\{r chunk-label, echo=TRUE, message=FALSE, warning=FALSE\}
library(tidyverse)
library(palmerpenguins)
library(ggthemes)

ggplot(data = penguins,
       mapping = aes(x = flipper_length_mm, y = body_mass_g)
) +
  geom_point(mapping = aes(color = species)) +
  geom_smooth(method = 'lm')
```
````````````

```{r chunk-label, echo=TRUE, message=FALSE, warning=FALSE}
library(tidyverse)
library(palmerpenguins)
library(ggthemes)

ggplot(data = penguins,
       mapping = aes(x = flipper_length_mm, y = body_mass_g)
) +
  geom_point(mapping = aes(color = species)) +
  geom_smooth(method = 'lm')
```

Tambem é possível apresentar resultados numéricos dentro do seu texto, como no seguinte exemplo.
```Markdown
A massa corporal média dos pinguins é `\r round(mean(penguins$body_mass_g, na.rm = T), 2)`
```
<span style="color: grey;">

A massa corporal média dos pinguins é `r round(mean(penguins$body_mass_g, na.rm = T), 2)`\

</span>

É importante ressaltar que a barra invertida não faz parte da sintaxe, mas foi necessária para que todo o código seja mostrado.

# Tabelas {.tabset .tabset-fade}

## Tabela feita na mão
Para fazer uma tabela sem a utilização do R diretamente no RMarkdown, observe e execute o seguinte código.

``` markdown
|direita|esquerda|padrão|centralizado|
|---:|:---|---|:---:|
|12|12|12|12|
|123|123|123|123|
|2|2|2|2|
```

| direita | esquerda | padrão | centralizado |
|--------:|:---------|--------|:------------:|
|      12 | 12       | 12     |      12      |
|     123 | 123      | 123    |     123      |
|       2 | 2        | 2      |      2       |

Veja que o caractere `|` é utilizado para delimitar o que fica dentro de cada célula, alem da segunda linha do código ter traços e pontos que dizem como vai ser o alinhamento do texto e delimita quem é nome das colunas.

## Tabelas com R
Há duas maneira interessantes de adicionar uma tabela com a utilização do R.\
<br>

- Para a primeira é necessário ter o pacote `knitr`, o pacote `kableExtra` e o pacote `palmerpenguins` instalados no seu pc. Execute o código `install.packages("knitr")`, `install.packages("kableExtra")` e `install.packages("palmerpenguins")` em seu console. Após isso você vai utilizar a função `library(knitr)` e `library(kableExtra)` para carregar o pacote e para poder ter acesso a sua função `kable()` e `kable_styling()`. Se você não quiser usar o library, é possível carregar o pacote e usar a função ao mesmo tempo com `knitr::kable()` e `kableExtra::kable_styling()`. Com isso em mente, observe e execute o seguinte código.
```{r}
library(palmerpenguins)

knitr::kable(head(penguins, 10)) |> 
  kableExtra::kable_styling(full_width = TRUE,
                            bootstrap_options = c("striped", "hover", "condensed", "responsive") 
                            )

```
Algumas informações importantes sobre os parâmetros utilizados nas funções:

|Código|Conceito|
|:---:|:---:|
|`palmerpenguins`|É o pacote onde está localizado o tibble (um tipo de base de dados) penguins|
|`kable(head(penguins, 10))`|Faz uma tabela com as 10 primeiras linhas|
|`kable_styling()`|Pemite mudar várias opções visuais. Os códigos dentro dessa função apenas especificam propriedades visuais|
|`full_width = TRUE`|Essa opção faz a tabela pegar toda a extensão do relatório|
|`striped`|deixa as cores das linhas alternadas|
|`hover`|destaca a linha quando passa o mouse|
|`condensed`|deixa a tabela mais condensada|
|`responsive`|quando diminui muito a tela ele adapta a tabela|

<br>

- Para a outra forma de fazer uma tabela com R você vai precisar do pacote `rmarkdown`. Desse modo, execute `install.packages("rmarkdown")`. Após isso, observe e execute o seguinte código.
```{r}
library(palmerpenguins)

rmarkdown::paged_table(penguins)
```

Com isso você tem uma boa forma para apresentar, dependendo do que for mais coveniente, poucos dados de uma tabela ou muitos dados de uma tabela.\
<br>
Você deve ter percebido a forte integração entre Markdown e R aqui no RStudio. Além de criar tabelas, você pode incorporar gráficos gerados pelo R e até mesmo realizar cálculos complexos com base em conjuntos de dados. Essa integração oferece uma ampla gama de possibilidades para criar documentos dinâmicos e interativos que combinam texto, código e resultados em um único ambiente.



# Referências











