当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


R encoded_text_to_latex 将非 ASCII 文本转换为 LaTeX 转义符


R语言 encoded_text_to_latex 位于 tools 包(package)。

说明

将文本中的非 ASCII 字符转换为 LaTeX 转义序列。

用法

encoded_text_to_latex(x,
                      encoding = c("latin1", "latin2", "latin9",
                                   "UTF-8", "utf8"))

参数

x

一个字符向量。

encoding

假定的编码。 "latin9" 正式为 ISO-8859-15 或 Latin-9,但在 LaTeX 的 inputenc 包中称为 latin9。

细节

中的非 ASCII 字符x被替换为适当的 LaTeX 转义序列,或‘⁠?⁠’如果没有合适的顺序。

即使有适当的顺序,所使用的字体也可能不支持该顺序。连字符映射到‘⁠\-⁠’。

x 长度相同的字符向量。

例子

x <- "fran\xE7ais"
encoded_text_to_latex(x, "latin1")
## Not run: 
## create a tex file to show the upper half of 8-bit charsets
x <- rawToChar(as.raw(160:255), multiple = TRUE)
(x <- matrix(x, ncol = 16, byrow = TRUE))
xx <- x
xx[] <- encoded_text_to_latex(x, "latin1") # or latin2 or latin9
xx <- apply(xx, 1, paste, collapse = "&")
con <- file("test-encoding.tex", "w")
header <- c(
"\\documentclass{article}",
"\\usepackage[T1]{fontenc}",
"\\usepackage{Rd}",
"\\begin{document}",
"\\HeaderA{test}{}{test}",
"\\begin{Details}\relax",
"\\Tabular{cccccccccccccccc}{")
trailer <- c("}", "\\end{Details}", "\\end{document}")
writeLines(header, con)
writeLines(paste0(xx, "\\"), con)
writeLines(trailer, con)
close(con)
## and some UTF_8 chars
x <- intToUtf8(as.integer(
    c(160:383,0x0192,0x02C6,0x02C7,0x02CA,0x02D8,
      0x02D9, 0x02DD, 0x200C, 0x2018, 0x2019, 0x201C,
      0x201D, 0x2020, 0x2022, 0x2026, 0x20AC)),
               multiple = TRUE)
x <- matrix(x, ncol = 16, byrow = TRUE)
xx <- x
xx[] <- encoded_text_to_latex(x, "UTF-8")
xx <- apply(xx, 1, paste, collapse = "&")
con <- file("test-utf8.tex", "w")
writeLines(header, con)
writeLines(paste(xx, "\\", sep = ""), con)
writeLines(trailer, con)
close(con)

## End(Not run)

也可以看看

iconv

相关用法


注:本文由纯净天空筛选整理自R-devel大神的英文原创作品 Translate non-ASCII Text to LaTeX Escapes。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。