如何在rmd文件中使用循环编织knit_print flextable

时间:2018-12-05 10:04:57

标签: r r-markdown knitr flextable

我正在尝试使用 flextable kable 软件包生成多张表。当我要迭代输出某些表时,我发现flextable的knit_print不在循环中工作。下面是一个最小的示例:

---
output: word_document
---

```{r}
library(flextable)
library(knitr)
```

```{r}
 data(cars)
     speed<-unique(cars$speed)
for (v in 1:length(speed)) {
  carspd<-cars[which(cars$speed==speed[v]),]
  tb<-regulartable(carspd)
knit_print(tb)
}
knit_print(tb)
```

最后一个knit_print可以将结果打印到带有.Rmd文件的word_document中。


现在,我在.md中发现了它们的区别,该```{=openxml} <w:tbl xmlns:w="....... 是通过带有superedit的pandoc进程文件输出的, 右表:

鈥媊``{=openxml}
<w:tbl xmlns:w="

错误的表:

{{1}}

在十六进制中有多余的内容:“ E2 80 8B”,有人称它们为零宽度空间吗?但是我不知道如何避免。

1 个答案:

答案 0 :(得分:1)

这是flextable在其knit_print方法中使用的功能之一的局限性:knitr::asis_output()不能在循环中使用。这里介绍了两种解决方案:https://github.com/yihui/knitr/issues/1137

这对我来说在HTML输出中起作用,只是将所有输出收集到一个大矢量中并在最后打印出来。我修改了代码,在表格之前也插入了一些文本,并在表格之后插入了一个数字。 我不使用Word,但我认为它也可以在其中工作:

---
output: html_document
---

```{r}
library(flextable)
library(knitr)
```

```{r}
data(cars)
speed <- unique(cars$speed)
results <- character()
for (v in 1:length(speed)) {
  carspd <- cars[which(cars$speed == speed[v]),]
  tb <- regulartable(carspd)

  # Generate a figure in a temporary file
  filename <- tempfile(fileext = ".png")
  png(filename)
  hist(carspd$dist)
  dev.off()

  # Put everything into the results vector
  results <- c(results, "\n\nThis is the table for v =", v,
                        knit_print(tb),
                        knitr:::wrap(include_graphics(filename)))

}
asis_output(results)
knit_print(tb)
```

一些注意事项:

  • 文本中的\n\n似乎是插入换行符所必需的。
  • knitr:::wrap()函数是knitr中未记录的内部函数,因此可能存在我不知道的限制,并且在某些将来的knitr版本中可能会失败。