如何使用 RMarkdown 使用胶水包进行折叠?
How can I make a collapse with glue package using RMarkdown?
我一直在尝试使用 glue 和 stargazer 包在乳胶中自动化一些 df table 的结果,但我没有得到任何结果(我想要的是“^{ *}" 出现在每个值旁边,因为它在 table) 中,然后使用 RMarkdown。
我想得到的:
我当前的丑陋且容易出错的修复:
library(dplyr)
library(glue)
library(stargazer)
X1 = c(4.70e1, 4.72e1, 4.76e1, 2.73e20)
X2 = c(4.67e1, 4.69e1, 4.77e1, 2.05e20)
tab.out = data.frame(X1, X2)
tab.out$max<-apply(tab.out, 1, max)
one = "1"
n.tab = tab.out %>%
mutate(test1 = if_else(tab.out$X2 < tab.out$max,
glue("\textsuperscript{*} is $<<one>>$.", .open = "<<", .close = ">>"), #It doesn't work with ^{*}
glue("")))
注意:one
只是为了测试崩溃,因为我试了glue_data
和glue_collapse
都没有用.
另一方面,假设崩溃有效,我该怎么做才能正确调试乳胶代码?因为我尝试使用 stargazer
、xtable
和 textreg
但在每个函数中它都无法识别 "\, }, ^{*}".
n.tab = n.tab[c(1,2,4)]
stargazer(n.tab, summary = F, header = F)
我得到了什么?
我使用提到的 paste0
函数实现了这一点 并根据@stefan 的推荐,但现在我想为 n 列自动化相同的函数
library(dplyr)
col.nam = c("AIC(n)", "HQ(n)", "SC(n)", "FPE(n)")
tab.out = data.frame(col.nam, X1, X2)
n.tab = tab.out %>%
mutate(test1 = if_else(tab.out$X1 < tab.out$X2,
paste0(X1,"$^{*}$"),
paste0(X1)),
test2 = if_else(tab.out$X2 < tab.out$X1,
paste0(X2,"\textsuperscript{*}"),
paste0(X2)))%>%
select(col.nam, test1, test2)
colnames(n.tab) = c("Parámetros", "Lag 1", "Lag 2")
print(xtable::xtable(n.tab,
header = F,
caption = "asdasdasdasd",
label="table:tb1",
caption.placement = "top",
align="llcc"),
hline.after = c(-1,0),
include.rownames=FALSE,
include.colnames = TRUE,
add.to.row = list(pos = list(nrow(n.tab)),
command = paste("\hline \n",
"\multicolumn{3}{l}{\footnotesize{$^{*}$Indica el orden de retraso seleccionado}} \\",
"\multicolumn{3}{l}{\footnotesize{\textit{Elaboración: Los autores}}}",
sep = "")), comment=FALSE,
sanitize.text.function = function(x){x})
我一直在尝试使用 glue 和 stargazer 包在乳胶中自动化一些 df table 的结果,但我没有得到任何结果(我想要的是“^{ *}" 出现在每个值旁边,因为它在 table) 中,然后使用 RMarkdown。
我想得到的:
我当前的丑陋且容易出错的修复:
library(dplyr)
library(glue)
library(stargazer)
X1 = c(4.70e1, 4.72e1, 4.76e1, 2.73e20)
X2 = c(4.67e1, 4.69e1, 4.77e1, 2.05e20)
tab.out = data.frame(X1, X2)
tab.out$max<-apply(tab.out, 1, max)
one = "1"
n.tab = tab.out %>%
mutate(test1 = if_else(tab.out$X2 < tab.out$max,
glue("\textsuperscript{*} is $<<one>>$.", .open = "<<", .close = ">>"), #It doesn't work with ^{*}
glue("")))
注意:one
只是为了测试崩溃,因为我试了glue_data
和glue_collapse
都没有用.
另一方面,假设崩溃有效,我该怎么做才能正确调试乳胶代码?因为我尝试使用 stargazer
、xtable
和 textreg
但在每个函数中它都无法识别 "\, }, ^{*}".
n.tab = n.tab[c(1,2,4)]
stargazer(n.tab, summary = F, header = F)
我得到了什么?
我使用提到的 paste0
函数实现了这一点
library(dplyr)
col.nam = c("AIC(n)", "HQ(n)", "SC(n)", "FPE(n)")
tab.out = data.frame(col.nam, X1, X2)
n.tab = tab.out %>%
mutate(test1 = if_else(tab.out$X1 < tab.out$X2,
paste0(X1,"$^{*}$"),
paste0(X1)),
test2 = if_else(tab.out$X2 < tab.out$X1,
paste0(X2,"\textsuperscript{*}"),
paste0(X2)))%>%
select(col.nam, test1, test2)
colnames(n.tab) = c("Parámetros", "Lag 1", "Lag 2")
print(xtable::xtable(n.tab,
header = F,
caption = "asdasdasdasd",
label="table:tb1",
caption.placement = "top",
align="llcc"),
hline.after = c(-1,0),
include.rownames=FALSE,
include.colnames = TRUE,
add.to.row = list(pos = list(nrow(n.tab)),
command = paste("\hline \n",
"\multicolumn{3}{l}{\footnotesize{$^{*}$Indica el orden de retraso seleccionado}} \\",
"\multicolumn{3}{l}{\footnotesize{\textit{Elaboración: Los autores}}}",
sep = "")), comment=FALSE,
sanitize.text.function = function(x){x})