I am authoring a report using RMarkdown, and using kable and kableExtra to format and print the table. Here is what I want would look like the table to look like (made in Wo
There doesn't seem to be a way to do this directly within kable and kableExtra. However, as when building a table to PDF through kable, it uses LaTeX to build the result. We can therefore integrate LaTeX functions directly into the table.
This solution uses the multirow
package. The cell to be centered vertically can be wrapped in \\multirow{1}{*}[0pt]{Cell content}
, as follows:
---
header-includes:
- \usepackage{multirow}
output: pdf_document
---
```{r}
library(knitr)
library(kableExtra)
df <- data.frame(a = letters[1:5], b = 1:5)
names(df) <- c("A very very very very very very very very very very very very very very very very very very long title",
"\\multirow{1}{*}[0pt]{A short title}")
df %>% kable(format = 'latex', linesep = "", align = 'c', escape = F) %>% kable_styling(full_width = T)
```
To make using this easier, you could make a function to do the renaming for you:
centerText <- function(text){
paste0("\\multirow{1}{*}[0pt]{", text, "}")
}
So to rename a column you run: centerText("A short title")