View source: R/as_kable_extra.R
| as_kable_extra | R Documentation | 
Function converts a gtsummary object to a knitr_kable + kableExtra object.
This allows the customized formatting available via knitr::kable()
and {kableExtra}; as_kable_extra() supports arguments in knitr::kable().
as_kable_extra() output via gtsummary supports
bold and italic cells for table bodies. Users
are encouraged to leverage as_kable_extra() for enhanced pdf printing; for html
output options there is better support via as_gt().
as_kable_extra(
  x,
  escape = FALSE,
  format = NULL,
  ...,
  include = everything(),
  addtl_fmt = TRUE,
  return_calls = FALSE
)
| x | ( | 
| format,escape,... | arguments passed to  | 
| include | Commands to include in output. Input may be a vector of
quoted or unquoted names. tidyselect and gtsummary select helper
functions are also accepted.
Default is  | 
| addtl_fmt | logical indicating whether to include additional formatting.
Default is  | 
| return_calls | Logical. Default is  | 
A {kableExtra} table
This section shows options intended for use with output: pdf_document in yaml of .Rmd.
When the default values of as_kable_extra(escape = FALSE, addtl_fmt = TRUE)
are utilized, the following formatting occurs.
Markdown bold, italic, and underline syntax in the headers, spanning headers, caption, and footnote will be converted to escaped LaTeX code
 Special characters in the table body, headers, spanning headers, caption,
and footnote will be escaped with .escape_latex() or .escape_latex2()
 The "\n" symbol will be recognized as a line break in the table
headers, spanning headers, caption, and the table body
 The "\n" symbol is removed from the footnotes
To suppress these additional formats, set as_kable_extra(addtl_fmt = FALSE)
Additional styling is available with
kableExtra::kable_styling() as shown in Example 2, which implements row
striping and repeated column headers in the presence of page breaks.
This section discusses options intended for use with output: html_document in yaml of .Rmd.
When the default values of as_kable_extra(escape = FALSE, addtl_fmt = TRUE)
are utilized, the following formatting occurs.
The default markdown syntax in the headers and spanning headers is removed
 Special characters in the table body, headers, spanning headers, caption,
and footnote will be escaped with .escape_html()
 The "\n" symbol is removed from the footnotes
To suppress the additional formatting, set as_kable_extra(addtl_fmt = FALSE)
Daniel D. Sjoberg
# basic gtsummary tbl to build upon
as_kable_extra_base <-
  trial |>
  tbl_summary(by = trt, include = c(age, stage)) |>
  bold_labels()
# Example 1 (PDF via LaTeX) ---------------------
# add linebreak in table header with '\n'
as_kable_extra_ex1_pdf <-
  as_kable_extra_base |>
  modify_header(all_stat_cols() ~ "**{level}**  \n*N = {n}*") |>
  as_kable_extra()
# Example 2 (PDF via LaTeX) ---------------------
# additional styling in `knitr::kable()` and with
#   call to `kableExtra::kable_styling()`
as_kable_extra_ex2_pdf <-
  as_kable_extra_base |>
  as_kable_extra(
    booktabs = TRUE,
    longtable = TRUE,
    linesep = ""
  ) |>
  kableExtra::kable_styling(
    position = "left",
    latex_options = c("striped", "repeat_header"),
    stripe_color = "gray!15"
  )
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.