skeleton.Rmd 3.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. ---
  2. title: "在R Markdown文档中使用中文"
  3. author:
  4. - 谢益辉
  5. - 邱怡轩
  6. - 于淼
  7. documentclass: ctexart
  8. output:
  9. rticles::ctex:
  10. fig_caption: yes
  11. number_sections: yes
  12. toc: yes
  13. classoption: "hyperref,"
  14. ---
  15. # 引言
  16. 中文LaTeX文档并非难题。当然这句话得站在巨人 [CTeX](http://ctex.org) 的肩膀上才能说,它让我们只需要一句
  17. ```latex
  18. \documentclass{ctexart} % 或者ctexrep/ctexbook
  19. ```
  20. 或者
  21. ```latex
  22. \usepackage{ctex}
  23. ```
  24. 就轻松搞定中文LaTeX排版问题。
  25. # 字体和选项
  26. LaTeX包[**ctex**](http://ctan.org/pkg/ctex)支持若干种字体选项,如果你是**ctex**老用户,请注意这里我们要求的最低版本是2.2,你可能需要升级你的LaTeX包。从版本2.0开始,**ctex**支持根据不同操作系统自动选择中文字体,简直是为人类进步作出了巨大贡献,我们再也不必费尽口舌向用户解释“啊,你用Windows啊,那么你该使用什么字体;啊,你用Mac啊,又该如何如何”。
  27. 下面的YAML元数据应该能满足多数用户的需求,主要设置两项参数:文档类为`ctexart`(当然也可以是别的类),输出格式为`rticles::ctex`,其默认LaTeX引擎为XeLaTeX(真的,别纠结你的旧爱PDFLaTeX了)。
  28. ```yaml
  29. ---
  30. documentclass: ctexart
  31. output: rticles::ctex
  32. ---
  33. ```
  34. `rticles::ctex`的参数都是普通的`pdf_document`参数,参见文档**rmarkdown**包的文档,这里就不赘述了。
  35. Windows和Mac用户应该都已经有自带的中文字体了。Linux用户可以考虑 [Fandol字体](http://ctan.org/pkg/fandol),它号称是免费的,不过我们也没太搞清楚它的来头。如果你不想操心这些问题,我们强烈建议你卸载你当前的 LaTeX 套装(TeX Live 或 MiKTeX 或 MacTeX),换上 TinyTeX,一切将会自动化搞定。
  36. ```{r eval=FALSE}
  37. devtools::install_github(c('rstudio/rmarkdown', 'yihui/tinytex'))
  38. tinytex::install_tinytex()
  39. ```
  40. # R代码段
  41. R代码用R Markdown的语法嵌入,即三个反引号开始一段代码```` ```{r} ````和三个反引号```` ``` ```` 结束一段代码:
  42. ```{r}
  43. options(digits = 4)
  44. fit = lm(dist ~ speed, data = cars)
  45. coef(summary(fit))
  46. b = coef(fit)
  47. ```
  48. 上面回归方程中的斜率是`r b[2]`,完整的回归方程为:$$ Y = `r b[1]` + `r b[2]`x$$
  49. 画图当然也是木有问题的啦,想画就说嘛,不说我怎么知道你想画呢?
  50. ```{r scatter, fig.cap='cars数据散点图以及回归直线。'}
  51. par(mar = c(4, 4, .1, .1), las = 1)
  52. plot(cars, pch = 19)
  53. abline(fit, col = 'red')
  54. ```
  55. 请不要问我为什么图浮动到下一页去了,这么初级的LaTeX问题问出来信不信我扁你。
  56. # 源代码控
  57. 这里提供的rticles模板可能由于种种原因不能满足客官的要求,LaTeX用户就是这样永无止境地调格式(唉,跟Word用户到底有啥区别呢)。若真是需要调整,你可以复制一份默认模板去改,如前面所说,本文档的模板是`rticles::ctex_template()`,它是一个文本文件。若熟悉LaTeX的话一看就明白,只不过里面有些Pandoc变量而已;若不熟悉LaTeX我们在这里说了也白说,花几天时间好好啃一啃LaTeX入门手册吧。
  58. 本文档所用的模板是从Pandoc默认LaTeX模板基础上做了少许改动而来的:https://github.com/yihui/pandoc-templates/blob/ctex/default.latex 具体改动从GIT提交消息日志中可以看到,主要就是去掉了mathspec包和hyperref包。
  59. # 小结
  60. 事实证明我们可以理直气壮地通过XeLaTeX将中文R Markdown转化为PDF文档,麻麻再也不用担心我的论文满屏幕都是反斜杠,朕养完小白鼠之后终于不必先折腾三个小时LaTeX再开始写实验报告了:打开RStudio,菜单File > New File > R Markdown,然后从模板中选择CTeX Documents,搞定。