R沟通|Rmarkdown(5)一些常用技巧

简介: 关于RMarkdown使用时,小编日常会使用的一些有用技巧,当然我也是通过学习谢大大的Rmarkdown-cookbook[1]以及日常使用需求上网搜的解决方案,在此分享给大家。如果大家还有其他什么需求,可以在留言板留言。或者有其他实用技巧也欢迎分享!

简介


关于RMarkdown使用时,小编日常会使用的一些有用技巧,当然我也是通过学习谢大大的Rmarkdown-cookbook[1]以及日常使用需求上网搜的解决方案,在此分享给大家。如果大家还有其他什么需求,可以在留言板留言。或者有其他实用技巧也欢迎分享!


1. 修改某些字体颜色🌟🌟🌟

Markdown语法没有用于更改文本颜色的内置方法。我们可以使用HTML和LaTeX语法来更改单词的格式

  • 对于HTML,我们可以将文本包装在标记中,并使用CSS设置颜色,例如 text 。
  • 对于PDF,我们可以使用LaTeX命令\textcolor{}{}。这需要使用LaTeX软件包xcolor,该软件包已包含在Pandoc的默认LaTeX模板中。

作为更改PDF文本颜色的示例:

我是\textcolor{blue}{庄闪闪}呀!欢迎关注我的\textcolor{red}{公众号}:\textcolor{blue}{庄闪闪的R语言手册}。

image.gif

在上面的示例中,第一组花括号包含所需的文本颜色,第二组花括号包含应将此颜色应用到的文本。


2. 更改全文页边距等 🌟🌟🌟

在top-level中加入geometry命令,例如

---
title: "RMarkdown常用技巧"
author:
  - 庄闪闪
documentclass: ctexart
geometry: "left=2cm,right=2cm,top=2cm,bottom=2cm"
output:
  rticles::ctex:
    keep_tex: true
    includes:
      in_header: columns.tex
    fig_caption: yes
    number_sections: yes
    toc: yes
---

这时的页边距就变成下面这样了:

5ZYU7H{V6J2A2HR57V_8YUF.png

当然全文字体大小等操作也是这样操作的,在geometry操作即可:

DZ]@{IFW2P%~SEI]U7K@7`W.png


3. 缩进文本 🌟🌟

默认情况下,Markdown还将忽略用于缩进的空格。但是,在某些情况下,例如在经文和地址中,我们可能希望保留缩进。在这些情况下,我们可以通过以竖线(|)开头的线来使用线块。换行符和所有前导空格将保留在输出中。例如:

| When dollars appear it's a sign
|   that your code does not quite align  
| Ensure that your math  
|   in xaringan hath  
|   been placed on a single long line

输出为:

image.gifXHMY%SQJWTB5IRQ)@]4UT8F.png


4. 分页

如果想要分页,可以使用\newpage。例如:如果想把目录和正文内容分开,可以在在正文前面加入这个代码

ECOYUJJ0~JH%0[JJ%S[K{LK.png

这时输出的结果,目录一个界面,正文另起一页。

_K5{VCT01PK9ALA5CGR~8)T.png


5. 控制文本输出的宽度🌟🌟

有时从R代码输出的文本可能太宽。如果输出文档具有固定的页面宽度(例如,PDF文档),则文本输出可能会超过页面的页边距。

R全局选项宽度可用于控制R函数输出的文本宽度,如果默认值太大,则可以尝试使用较小的值。此选项通常表示每行字符的粗略数目。例如:

```{r}
options(width = 300)
matrix(runif(100), ncol = 20)
```

image.gifL4S}EX}D(5TJPXU9%ZOYVTA.png

```{r}
options(width = 60)
matrix(runif(100), ncol = 20)
```

image.gifC[S[$CBEPAYQTE]XOT8)A81.png

但是这种方式不一定对所有函数都适用,这是你可以使用其他方式,对于Html(这里不做解释,主要将pdf),可以参见教程[2]

对于PDF输出,换行比较困难。一种解决方案是使用LaTeX软件包清单,可以通过Pandoc参数--listings启用它。然后,您必须为此软件包设置一个选项,并且可以从外部LaTeX文件中包含设置代码(有关详细信息,请参见第6.1[3]节),例如,

---
output:
  pdf_document:
    pandoc_args: --listings
    includes:
      in_header: preamble.tex
---

在preamble.tex中(建议放到和rmd同一个文件夹),我们设置了Listings包的一个选项:

\lstset{
  breaklines=true
}

这是输出的结果,但是其实不是很美观

4W]GLW%L~%@8A[V_]MK0[NV.png


6. 控制图片输出大小🌟🌟🌟

这个我在文稿和教程中说的挺清楚了。可见:R沟通|Rmarkdown教程(3)R沟通|Rmarkdown教程(2)一共有两种方式:

方法一:chunck中加入out.width="50%"

```{r, echo=FALSE, out.width="50%", fig.cap="A nice image."}
knitr::include_graphics("foo/bar.png")
```

方法二:markdown语法设置{width=50%}

![A nice image.](foo/bar.png){width=50%}


7. 图片对齐🌟🌟🌟

这个我也说过啦!可见:R沟通|Rmarkdown教程(3)R沟通|Rmarkdown教程(2)。如果使用R代码导入图片的话,使用knitr::include_graphics()并结合R chunk中fig.align = 'center'参数进行居中。如果结果不想显示代码块,可在chunck中加入:echo=FALSE

任何输出形式都适用,推荐使用

knitr::include_graphics()

当然还有另一种方法,不使用代码形式。对于输出为html,你可以使用html语法(不适用于pdf/word)

\center
![](image.png)
\center

对于输出pdf/word可以使用以下方式

<center> ![](image.png) </center>

当然想要文字居中的话,也是这样使用

视频教程可见我的b站,讲的很详细了:号外!Rmarkdown教程全网发布


8. 代码块的行号🌟

通过块选项 attr.source =“ .numberLines”将行号添加到源代码块中,或者通过attr.output =“ .numberLines”将文本输出块添加到文本中,例如,

```{r, attr.source='.numberLines'}
if (TRUE) {
  x = 1:10
  x + 1
}
```

输出结果为:

5WQMQVHXW3OTJ)``GP)BEIQ.png


9. 多列输出🌟🌟🌟

这个特别好用!虽然学起来有那么一点困难,具体我再出一期推文,把这个讲清楚。具体可以见这里的教程[4]。类似于排版成这种形式,可以任意排版你想要输出的界面形式。

1%ANV$@}{ZM@I{1AOM$1I9H.png


目录
相关文章
|
存储 安全 数据管理
PMBOK泛读(第十章) - 项目沟通管理
PMBOK泛读(第十章) - 项目沟通管理
106 0
|
6月前
|
数据挖掘
R沟通|Rmarkdown教程(1)
R沟通|Rmarkdown教程(1)
69 0
|
计算机视觉
R沟通|Rmarkdown构建简历并部署到个人网站
上一期已经对使用 latex 模板构建 cv 做了较为详细的说明:R沟通|使用latex模板构建个人履历。但是存在一个问题:Latex 最后输出的是 pdf 版本,如果你想把他部署到自己的个人网站上,可能就比较费劲了(害,是我不会)。所以请教了李康国学弟之后,我又尝试了下使用 Rmarkdown 构建 cv 并将其部署到 gitee中,这样所有人都可以通过网址访问我的 cv 了。
327 0
R沟通|Rmarkdown构建简历并部署到个人网站
|
运维 前端开发 程序员
一个切图仔的工作沟通日常
一个切图仔的工作沟通日常
99 0
|
开发工具 IDE Python
R沟通|Rmarkdown教程(2)
假设你已经安装了R[1](R Core Team 2020)和RStudio IDE[2]。
1028 0
R沟通|Rmarkdown教程(2)
R沟通|Rmarkdown教程(3)
这里小编给出一些常用的选项,文字版本较难理解的话,请配合我的b站视频教程[1]。
486 0
R沟通|Rmarkdown教程(3)
R沟通|Rmarkdown教程(4)
Rmarkdowm作为可复用报告的优秀工具,除了提供文档编辑、图表输出外,还有许多主题格式供使用者选择。除了默认的主题外,还可以通过加载rticles、prettydoc、rmdformats、tufte等包获取更多主题格式。下面我们看看几类扩展包里的主题样式。
243 0
R沟通|Rmarkdown教程(4)
|
前端开发 JavaScript 数据可视化
R文档沟通|Dashboards入门(3)
前面推了两期有关dashboards的推文,可见:R文档沟通|Dashboards入门(1);R文档沟通|Dashboards入门(2)
218 0
R文档沟通|Dashboards入门(3)
|
数据可视化
R文档沟通|Dashboards入门(1)
在本章中,我们将介绍基于 flexdashboard[1] 包的仪表盘。 仪表盘在业务风格的报告中特别常见。它们可以用来突出报告的概要和关键内容。仪表盘的布局通常是基于网格搭建的,各个组件排列在各种大小的“盒子”中。
150 0
R文档沟通|Dashboards入门(1)
|
数据可视化
R文档沟通|Dashboards入门(2)
关于仪表盘布局的总体规则是: • 一级标题:生成页面; • 二级标题:生成列(或行); • 三级标题:生成框(包含一个或多个仪表盘组件)。
115 0
R文档沟通|Dashboards入门(2)