4

出于发布的目的,我经常需要我的工作的 PDF 和 HTML 版本,包括回归表,我想使用 R Markdown。对于 PDFstargazertexreg软件包,它们会生成精美的表格。现在尝试生成同样有吸引力的 HTML 输出,我面临着不同的问题。

  1. HTML 输出的两种方法在注释中都缺少重要的星号。由于它们是自动生成的,我不知道如何逃避它们。(我认为这可能是一个小问题,因此我不想将其拆分为单独的问题。) 注意:子问题已在此处回答。

  2. 在创建明确的输出之前,我经常需要更改我的数据或进行一些格式化。我发现总是在手动之间type='html'切换选项很烦人。type='pdf'我想知道是否有一种更可行的方法来组合 html/pdf 输出texreg,例如在/中进行 case-to-case 切换stargazer和整洁的输出?

我尝试了有希望的pander-solution,但自 2014 年以来它似乎不再工作了。pixiedust也不是很令人满意,它最终变得有点手动,而不是我想要的。另一个例子似乎只涉及普通表。

非常感谢任何帮助,谢谢!

这是我knitr在 HTML 和 PDF 中尝试的总结:

```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = TRUE)
```
```{r table, results = "asis"}
library(car)
lm1 <- lm(prestige ~ income + education, data=Duncan)

## html
# stargazer
library(stargazer)
stargazer(lm1, type="html", notes="stargazer html")
# htmlreg
library(texreg)
htmlreg(lm1, custom.note="%stars. htmlreg")

## pdf/latex
# stargazer
stargazer(lm1, notes="stargazer latex")
# texreg
texreg::texreg(list(lm1), custom.note="%stars. texreg")

# pixiedust
library(pixiedust)
dust(lm1, caption = "pixiedust")

# pander
library(memisc)
library(pander)
lm1_table <- mtable(lm1)
# pander(lm1_table, style="rmarkdown") # not working
pander(lm1)
```
4

2 回答 2

3

这是一个提议:创建一个检查输出格式的函数,然后根据此使用 stargazer 或 texreg。我们opts_knit$get("rmarkdown.pandoc.to")用来检查输出格式。

---
output: html_document
---

```{r setup, include=FALSE}
library(knitr)
opts_chunk$set(echo = TRUE)
rmd_format <- opts_knit$get("rmarkdown.pandoc.to")
## returns "html" or "latex"

```

```{r}

report_regression <- function(model, format, ...){
  if(format == "html"){
    require(texreg)
    htmlreg(model, custom.note="%stars. htmlreg", ...)
  } else if(format == "latex"){
    require(stargazer)
    stargazer(model, notes="stargazer html", ...)
  } else {
   print("This only works with latex and html output") 
  }
}
```

```{r table, results = "asis"}
library(car)
lm1 <- lm(prestige ~ income + education, data=Duncan)

report_regression(lm1, format = rmd_format)
```
于 2017-06-12T09:56:40.620 回答
2

正如对相关问题的回答中所指出的,knitr1.18引入了以下功能

knitr::is_html_output()
knitr::is_latex_output()

检查输出是 HTML 还是 LaTeX。改编@scoa的优秀答案:

---
output: html_document
---

```{r}

report_regression <- function(model, ...){
  if(knitr::is_html_output()){
    require(texreg)
    htmlreg(model, custom.note="%stars. htmlreg", ...)
  } else if(knitr::is_latex_output()){
    require(stargazer)
    stargazer(model, notes="stargazer html", ...)
  } else {
   print("This only works with latex and html output") 
  }
}
```

```{r table, results = "asis"}
library(car)
lm1 <- lm(prestige ~ income + education, data=Duncan)

report_regression(lm1)
```
于 2019-02-07T03:41:31.617 回答