I have a bunch of quite big tables in markdown that I created manually. I was using them in an Rmd document. Since I need more control with LaTeX and all, I am using a Rnw document. How can I put my markdown table in the Sweave file?
Below a minimal example (not working):
\documentclass{article}
\begin{document}
\SweaveOpts{concordance=TRUE}
% my markdown table
col1 | col2 | col3
------|:---:|:---:
row1 | cell1 | cell2
row2 | cell3 | cell4
row3 | cell5 | cell6
\end{document}
I've tried to convert the table inside the document, just to paste the table in markdown in the Sweave document, and get it rendered in LaTeX. My try yields errors, but I am closer:
\documentclass{article}
\begin{document}
\SweaveOpts{concordance=TRUE}
<<texifytable, echo=FALSE, results=tex>>=
mytab = sprintf("col1 | col2 | col3
------|:---:|:---:
row1 | cell1 | cell2
row2 | cell3 | cell4
row3 | cell5 | cell6")
system2("pandoc", args = c("-f markdown","-t latex"),
stdout = TRUE, input = mytab)
@
\end{document}
It's doable:
\documentclass{article}
\usepackage{longtable}
\usepackage{booktabs}
\begin{document}
<<echo = FALSE, results = "asis", message = FALSE>>=
library(knitr)
markdown2tex <- function(markdownstring) {
writeLines(text = markdownstring,
con = myfile <- tempfile())
texfile <- pandoc(input = myfile, format = "latex", ext = "tex")
cat(readLines(texfile), sep = "\n")
unlink(c(myfile, texfile))
}
markdowntable <- "
col1 | col2 | col3
-----|:----:|:----:
row1 | cell1 | cell2
row2 | cell3 | cell4
row3 | cell5 | cell6
"
markdown2tex(markdowntable)
@
\end{document}
I wrapped the code in a small helper function markdown2tex
. This makes the code quite slim when using it with several markdown tables.
The idea is to simply copy the markdown table in the document and assign it as character string to an object (here: markdowntable
). Passing markdowntable
to markdown2tex
includes the equivalent LaTeX table into the document. Don't forget to use the chunk options results = "asis"
and message = FALSE
(the latter in order to suppress messages from pandoc
).
The workhorse in markdown2tex
is knitr::pandoc
. With format = "latex", ext = "tex"
it converts the input
to a TEX fragment and returns the path to the TEX file (texfile
). As pandoc
needs a filename as input, the markdown string is written to a temporary file myfile
. After printing the contents of texfile
to the document, myfile
and texfile
are deleted.
Of course, if the markdown tables are already saved in files, these steps can be simplified. But personally, I like the idea of having a markdown string in the RNW file. That way, it can be easily edited, the content is clear and it supports reproducibility.
Note: You need to add \usepackage{longtable}
and \usepackage{booktabs}
to the preamble. The TEX code generated by pandoc
requires these packages.
The example above produces the following output: