How to gsub('%', '\%', … in R?

China☆狼群 提交于 2019-12-11 02:37:56

问题


I want to export a latex table with a units column that has the percent (%) symbol.

library(xtable) 
foo <- data.frame(units='%', citation = '\\citep{authorYYYYabc}')
print(xtable(foo), sanitize.text.function = function(x) {x})

note: above code has been changed since Joris' answer.

In this case, the '%' is interpreted as a comment by LaTeX.

I have tried

gsub('%', '\\%', foo)

returns

[1] "1"

how can I convert the % to \% so that LaTex comments it out?

This question is a little bit like a previous question "can R paste('\')?"; even polishing the same table, but I can't figure out this particular case.


回答1:


Combining Joris' answer with the codes in the comment:

library(xtable)
foo <- data.frame(units='%', citation = '\\citep{authorYYYYabc}')
print(xtable(foo), sanitize.text.function = function(x)gsub('%', '\\\\%', x))



回答2:


I'm not sure if I understand you completely correctly. If I do xtable(foo), then the % is correctly escaped :

...
  \hline
1 & \% \\ 
   \hline
...

If you want to make an escape slash for something else, you need a quadruple one in gsub :

> x <- gsub('%', '\\\\%', foo[,1])
> x
[1] "\\%"
> cat(x,"\n")
\% 

Mind you, you cannot gsub in a dataframe, only in a vector. This can be shown by

> as.character(foo)
[1] "1"


来源:https://stackoverflow.com/questions/5031999/how-to-gsub-in-r

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!