Gai*_*inz 1 r knitr r-markdown kableextra kable
我目前必须.pdf使用R Markdown. 我正在使用该knitr包将我的数据帧“转换”为 LaTeX。我通常这样做没有问题,但这次我不太确定如何解决我的问题。
我需要获取列表中每个元素(某些数据框)的标题,以在.pdf文件中显示为标题。
这是我拥有的数据示例:
library(knitr)
library(kableExtra)
df1 <- data.frame(col1 = c(1,2,3), col2 = c("a", "b", "c"))
df2 <- data.frame(col1 = c(6,7,8), col2 = c("d", "e", "f"))
list <- list("df1" = df1, "df2" = df2)
print(list)
$`df1`
col1 col2
1 1 a
2 2 b
3 3 c
$df2
col1 col2
1 6 d
2 7 e
3 8 f
Run Code Online (Sandbox Code Playgroud)
我的knitr和kableExtra代码:
my_function <- function(list){
kable(list, "latex", longtable = T,
caption = "df1 and df2 respectively") %>%
kable_styling(font_size = 7,
latex_options = c("repeat_header"),
full_width = F)
}
print(lapply(list, my_function))
Run Code Online (Sandbox Code Playgroud)
目前,输出文档上两个表格的标题是df1 and df2 respectively我希望df1第一个和df2第二个表格的标题,依此类推...
我不习惯list()里面,kable()因为我主要使用data.frame/data.table。我尝试caption使用names(), cat(), ...替换with 参数,但没有得到我想要的结果。我很确定这很简单。
任何人都可以帮助我吗?谢谢你。
您可以在 for 循环中单独打印表,正如这里所建议的:当从 lapply 或从带有打印语句的函数调用时 kable 的意外行为。
---
title: "List of tables"
output:
pdf_document
header-includes:
- \usepackage{longtable}
---
```{r tables, results = "asis", echo = FALSE}
library(knitr)
library(kableExtra)
## data
df1 <- data.frame(col1 = c(1,2,3), col2 = c("a", "b", "c"))
df2 <- data.frame(col1 = c(6,7,8), col2 = c("d", "e", "f"))
ls <- list(df1 = df1, df2 = df2)
## tables
for(i in seq_along(ls)) {
print(
kable(ls[[i]], format = "latex", caption = names(ls)[i], longtable = TRUE) %>%
kable_styling(font_size = 7, latex_options = "repeat_header", full_width = FALSE)
)
}
```
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1249 次 |
| 最近记录: |