【发布时间】:2011-10-05 13:56:09
【问题描述】:
定义:
df <- data.frame(name=c("México","Michoacán"),dat=c(1,2))
s.t.
> df
name dat
1 México 1
2 Michoacán 2
当我使用xtable 将此表打印到.tex 文件时,重音字符会出现乱码,这不足为奇。
我想用正确的Latex 格式替换重音符号,例如:
> df
name dat
1 M\'{e}xico 1
2 Michoac\'{a}n 2
请注意,在实际数据集中,有许多不同的名称具有不同的重音字母,但都具有相同类型的重音(即正斜杠),因此\'{.} 中唯一需要更改的是字母代替点。
在尝试一位读者的建议时,我做了以下事情:
> df <- data.frame(name=c("México","Michoacán"),dat=c(1,2))
> df
name dat
1 México 1
2 Michoacán 2
> df$name <- sub("é", "\\\\'{e}", df$name,)
> df
name dat
1 M\\'{e}xico 1
2 Michoacán 2
> capture.output(
+ print(xtable(df)),
+ file = "../paper/rTables.tex", append = FALSE)
当我在记事本中打开 rTables.tex 文件时:
% latex table generated in R 2.13.1 by xtable 1.5-6 package
% Fri Jul 15 13:19:17 2011
\begin{table}[ht]
\begin{center}
\begin{tabular}{rlr}
\hline
& name & dat \\
\hline
1 & M$\backslash$'\{e\}xico & 1.00 \\
2 & Michoacán & 2.00 \\
\hline
\end{tabular}
\end{center}
\end{table}
这不是我们需要的。
【问题讨论】:
标签: string r diacritics data-manipulation xtable