Я пытаюсь настроить knitr::knit_hooks()
для автоматического форматирования вывода фрейма данных фрагмента R-markdown с kableExtra
в моем отчете HTML.
Я не хотел бы повторно добавлять следующие строки(или любые строки) до конца каждого куска табулированных данных:
head(iris) %>%
kable("html") %>%
kable_styling("hover", full_width = FALSE)
Я придумал одно решение на основе этого ответа , которое работает путем оценки источника куска (см. Мой ответ ниже , который включает некоторые проблемы, которые у меня возникают с этим подходом);Я надеюсь, что может быть лучшее решение, используя чанк output .
Вот пример .Rmd с описанием того, чего я хотел бы достичь.
---
title: "Untitled"
author: "Paul"
date: "25 September 2018"
output: html_document
---
```{r setup, include = F}
library(dplyr)
library(kableExtra)
library(knitr)
data(iris)
default_source_hook <- knit_hooks$get('source')
knit_hooks$set(
output = function(x, options) {
x %>%
kable("html") %>%
kable_styling("hover", full_width = FALSE)
},
source = function(x, options) {
if(is.null(options$table))
default_source_hook(x, options)
else {
eval(parse(text = x)) %>%
kable("html") %>%
kable_styling("hover", full_width = F)
}}
)
```
Desired chunk input:
```{r test, echo = F}
head(iris)
```
Desired output will look like:
```{r output, echo = F}
head(iris) %>%
kable("html") %>%
kable_styling("hover", full_width = FALSE)
```
Solution using the source chunk output:
```{r table_format, results = "hide", table = T, eval = F}
head(iris)
```
Спасибо.