Создать таблицу в формате PDF

Есть ли способ создать PDF таблицы из R так же, как вы строите график (например, с помощью pdf () или ggsave ())? Я понимаю, что есть способы с другими программами (используя sweave и т. Д.), Но я хотел бы сделать это только из R.

Ответы на вопрос(4)

Вот одна строка, использующая мою библиотеку:

library(huxtable)
my_table <- table(mtcars$gear, mtcars$cyl)
quick_pdf(my_table) # produces a PDF in the current directory

grid.table вgridExtra, используя сетку графики.

но мне не понравился формат выводаgrideExtra или жеtextplot поэтому я написал эту функцию, чтобы сделать это в латексе. Это немного хакерская работа, и есть лучшие способыsweave или жеknitr, но вы можете найти полезным изменить для ваших целей:

createPDF <- function(xx, name=deparse(substitute(xx))){
  require(xtable)
  tt <- print(xtable(xx), type='latex')
  texfile <- paste0('./reports/', name, '.tex')
  cat(
    '\\documentclass[12pt]{report}
\\usepackage[landscape]{geometry}
\\date{}
\\begin{document}', tt, '\\end{document}', sep='', 
    file=texfile
  )
  ## pdflatex from texlive package for linux converts .tex to .pdf
  system(paste0('pdflatex ', '-output-directory ./reports ', texfile))
}
Решение Вопроса

вы можете поместить текст в графики и, следовательно, в устройства PDF.

Самой хорошей оберткой для этого может бытьtextplot() функция в доверенных Грег Уорнсgplots пакет. Ниже приведено начало раздела примеров на странице справки:

# show R version information
textplot(version)
# show the alphabet as a single string
textplot( paste(letters[1:26], collapse=" ") )

# show the alphabet as a matrix 
textplot( matrix(letters[1:26], ncol=2))

### Make a nice 4 way display with two plots and two text summaries 
data(iris)  
par(mfrow=c(2,2))   
plot( Sepal.Length ~ Species, data=iris, border="blue", col="cyan",   
      main="Boxplot of Sepal Length by Species" )    
plotmeans(Sepal.Length ~ Species, data=iris, barwidth=2, connect=FALSE,
          main="Means and 95\% Confidence Intervals\nof Sepal Length by Species")

info <- sapply(split(iris$Sepal.Length, iris$Species),
               function(x) round(c(Mean=mean(x), SD=sd(x), N=gdata::nobs(x)),2))

textplot( info, valign="top"  )
title("Sepal Length by Species")

reg <- lm( Sepal.Length ~ Species, data=iris )
textplot( capture.output(summary(reg)), valign="top")
title("Regression of Sepal Length by Species")

par(mfrow=c(1,1))
 Tom07 окт. 2010 г., 15:34
Спасибо, похоже, работает!

Ваш ответ на вопрос