按照上一个问题,我想我可以首先将stargazer(汇总统计表的乳胶代码)的输出转换为png,在R块中使用R命令(如dvi,dvips,...),或者在最坏的情况下,调用系统命令(参见这篇文章),然后使用类似的命令将生成的 png 导入我的 Rmd 文件
![alt text](summary_lm.png)
你认为这可能吗?你能告诉我怎么做吗,因为我没有运气?
您可以使用object
标签将 PDF 文件嵌入 HTML 文件(但并非所有 Web 浏览器都支持)。
一个棘手的问题是 LaTeX 生成的 PDF 文件的大小必须提前设置;但是,要显示表格,您可能更喜欢 PDF 文件的大小与表格的大小完全相同,以避免出现较大的空白边距和/或滚动条。您可以使用 GhostScript 裁剪 PDF 文件。
这是一个例子。
# Sample data
library(stargazer)
example(stargazer)
code <- .Last.value$value
# Generate the LaTeX file
file <- tempfile("latex_", fileext = "")
tex_file <- paste( file, "tex", sep="." )
pdf_file <- paste( file, "pdf", sep="." )
pdf_file2 <- paste( file, "_cropped.pdf", sep="" )
png_file <- paste( file, "png", sep="." )
html_file <- paste( file, "html", sep="." )
cat(
"\\documentclass{report}",
# Unreasonably tall page size: we want everything on the same page
"\\usepackage[paperwidth=10cm,paperheight=100cm,noheadfoot,margin=0in]{geometry}",
"\\begin{document}",
"\\pagestyle{empty}",
paste(code, collapse="\n"),
"\\end{document}\n",
sep="\n",
file = tex_file
)
# Generate the PDF file
old_wd <- getwd()
setwd( tempdir() )
system(paste( "pdflatex --interaction=nonstopmode", shQuote(tex_file) ))
# We need to crop the file.
# I will use Ghostscript, but you could also use
# http://pdfcrop.sourceforge.net/
# or
# http://www.ctan.org/tex-archive/support/pdfcrop
# First, find the dimensions
bbox <- system(paste( "gs -sDEVICE=bbox -dNOPAUSE -dBATCH -f", pdf_file, "2>&1" ), intern=TRUE)
bbox <- bbox[ grep("%%BoundingBox", bbox) ]
bbox <- as.numeric( strsplit(bbox, " ")[[1]][-1] )
# Then, crop the file
cmd <- paste(
"gs -sDEVICE=pdfwrite",
"-o", pdf_file2,
"-c \"[/CropBox [", paste(bbox, collapse=" "), "] /PAGES pdfmark\"",
"-f", pdf_file
)
system(cmd)
# Convert it to PNG, in case the browser cannot display inline PDF files.
# This assumes that ImageMagick is installed.
# You may want to play with the options to have a better quality and/or larger file.
system(paste( "convert", "-trim", "-density 400", pdf_file2, "-resize 50%", png_file ))
# You can now include it in an HTML file
# (or a Markdown file, since you can include raw HTML).
cat(
"<html><body><p>Here is an embedded PDF file.</p>\n",
"<object width='100%' height='100%' type='application/pdf' data='", pdf_file2, "'>",
"<img src='", png_file, "'/>",
"</object>\n",
"</body></html>",
sep="",
file=html_file
)
# Check that the result can be displayed in your browser
# (Chrome should be fine, but I have not had any success with the others.)
browseURL( html_file )