Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
1.6k views
in Technique[技术] by (71.8m points)

r - How to convert an html sjtable from the sjPlot package to latex

The sjPlot package (http://www.strengejacke.de/sjPlot) has the tab_model() function to create beautiful html tables for lots of model types. I am trying to use those tables in Overleaf, but I am not sure how to "easily" convert them to latex without losing some of the formatting, etc.

My very hacky approach has been the following (posted it in https://github.com/Rapporter/pander/issues/298).

Any help improving this would be appreciated.

Below, a reproducible example:

library(lme4)
library(sjPlot)
library(XML)
library(RCurl)
library(rlist)
library(janitor)
library(dplyr)
library(knitr)

# This is a terrible model
model = lmer(mpg ~ cyl * disp + (1|vs), mtcars)

# We save the sjPlot table to an .html file (see the table below)
sjPlot::tab_model(
  model,
  show.r2 = TRUE,
  show.icc = FALSE,
  show.re.var = FALSE,
  p.style = "scientific",
  emph.p = TRUE,
  file = "Downloads/temp.html")

enter image description here

Now we can read the .html file and clean it up a bit:

tables <- list.clean(readHTMLTable("~/Downloads/temp.html"), fun = is.null, recursive = FALSE)
tables2 = tables[[1]] %>% janitor::row_to_names(row_number = 1)
tables2 <- as.matrix(tables2) %>% as_tibble()
tables2[is.na(tables2)] <- ""

So now we have the html table in a "clean" dataframe, and we can use kable() to see it in the terminal:

knitr::kable(tables2, format = "pipe")

With this final kable() call we can create the latex code below, which is a reasonable approximation to the initial table... although some important things are missing (bold p values, VD top row...)

kable(
  tables2,
  format = "latex",
  booktabs = TRUE,
  col.names = names(tables2),
  align = c("l", rep("c", length(names(tables2)) - 1)),
  caption = "Means and Standard Deviations of Scores on Baseline Measures"
)

Latex code:

egin{table}

caption{label{tab:}Means and Standard Deviations of Scores on Baseline Measures}
centering
egin{tabular}[t]{lccc}
oprule
Predictors & Estimates & CI & p\
midrule
(Intercept) & 49.04 & 39.23 – 58.85 & 1.144e-22\
cyl & -3.41 & -5.05 – -1.76 & 5.058e-05\
disp & -0.15 & -0.22 – -0.07 & 2.748e-04\
cyl * disp & 0.02 & 0.01 – 0.03 & 1.354e-03\
N vs & 2 &  & \
addlinespace
Observations & 32 &  & \
Marginal R2 / Conditional R2 & 0.809 / NA &  & \
ottomrule
end{tabular}
end{table}

This is the latex end result:

enter image description here

Of course, this is a toy example, with more complex models, the formatting issues pile up a bit...

See Question&Answers more detail:os

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

In case is useful to someone (and for my future self), I created a Github repo with a function that gets a sjPlot::tab_model() html output and builds tex (and pdf) versions of it. So, using the table above:

# Load html2pdf.R function
source("R/html2pdf.R")
    
# Create tex and pdf
html2pdf(filename = "temp.html", page_width = 13, build_pdf = TRUE, silent = TRUE)

The end result is:

enter image description here

This seems to work for more complex tables too.

Thanks to tjebo, now you can install this as a package and works on Linux and Mac: remotes::install_github("gorkang/html2latex")


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...