kableExtra乳胶代码不适用于粗体字

时间:2019-04-22 10:48:43

标签: r latex kable kableextra

我试图用kableExtra创建一些表,以便以后在外部乳胶文档上使用它们,因此我想将该表导出为.tex文档。除非我尝试在某些行中使用粗体字,否则此方法效果很好。

这是我正在使用的代码的MWE:

require(kableExtra)
require(dplyr)

bold_letters = c(1,0,1)
df = cbind.data.frame("Noms" = c("A", "B", "C"), "var1" = c(1,2,3))

df %>% 
  mutate(Noms = cell_spec(Noms, bold = ifelse(bold_letters==0,FALSE,TRUE))) %>%
  kable(format = "latex", escape = F, row.names = F, align = "c")

问题在于黑体字。如果我将其放入markdown并进行编织,则可以正常工作,但是如果我尝试导出tex代码,则会得到类似的信息:

\begin{tabular}{c|c}
\hline
Noms & var1\\
\hline
<span style=" font-weight: bold;    " >A</span> & 1\\
\hline
<span style="     " >B</span> & 2\\
\hline
<span style=" font-weight: bold;    " >C</span> & 3\\
\hline
\end{tabular}

据我所知,这不是乳胶代码。

PS:我可以创建表格并将其导出为图像,但是质量很差,而且它在表格的两边都包含白色带作为图像的一部分,因此不切实际。

1 个答案:

答案 0 :(得分:1)

也许不用dplyr就可以做到。您还需要在format="latex"中使用cell_spec,否则它将格式化HTML。

library(kableExtra)
bold_letters <- c(1,0,1)
df <- cbind.data.frame(Noms=c("A", "B", "C"), var1=c(1, 2, 3))
df$Noms <- cell_spec(df$Noms, format="latex", 
                     bold=ifelse(bold_letters == 0, FALSE, TRUE))

kable(df, format="latex", escape=FALSE, row.names=FALSE, align="c")
# \begin{tabular}{c|c}
# \hline
# Noms & var1\\
# \hline
# \textbf{A} & 1\\
# \hline
# B & 2\\
# \hline
# \textbf{C} & 3\\
# \hline
# \end{tabular}