![](/img/trans.png)
[英]Two-column mode in standard R Markdown for pandoc pdf output
[英]two-column layouts in RStudio presentations/slidify/pandoc
我正在努力想出一个很好的系统来生成幻灯片和随附的讲义。 理想的系统具有以下属性:
pandoc
幻灯片分隔符格式(在指定级别的标题之后自动生成新幻灯片)是首选 sed
),但不想写一个庞大的基础设施 以下是我迄今为止发现的各种选项:
RStudio
演示文稿( .Rpres
文件):
pandoc
幻灯片分隔符格式 rmarkdown
第2版捆绑在一起。 它以.Rpres
格式解决了上述许多问题。 pandoc
:可能是唯一具有脚注,参考书目支持等功能的降价转换器。我也可以使用pandoc
来生成使用tufte-handout类的 LaTeX,这符合我的美容标准。
pandoc -s -S -i -t dzslides --mathjax knitr-slides.md -o knitr-slides.html
,但它似乎不是...... Rnw
(knitr-dialect Sweave)而不是R markdown开始。 这会给我最大的灵活性......
毕竟,我的具体问题是: 为HTML输出生成两列布局的最佳(最简单)方法是什么 ?
任何其他建议也将不胜感激。
这是一个古老的Q,但最近我被一个类似的问题困扰,这是我发现的:
使用RPres格式,可以像这样指定两列( 详细信息 )。 请注意,RPres只能通过单击RStudio中的按钮转换为HTML,似乎没有任何命令行方法,这有点烦人。 尽管如此,我认为它是目前使用markdown获取幻灯片列的最简单,最灵活的方法:
===
Two Column Layout
===
This slide has two columns
***
```{r, echo=FALSE}
plot(cars)
```
通过调整色谱柱比例可以提供一些灵活性:
===
Two Column Layout
===
left: 30%
This slide has two columns
***
```{r, echo=FALSE}
plot(cars)
```
使用rmarkdown我们可以获得两列,但无法控制中断的位置,这有点问题:
---
output: ioslides_presentation
---
## Two Column Layout {.columns-2}
This slide has two columns
```{r, echo=FALSE}
plot(cars)
```
我们还可以使用RStudio中的beamer_presentation
格式在一个Rmd文件中混合markdown和LaTeX来获得这样的两列,但不能在任一列中运行任何代码,这是一个限制:
---
output: beamer_presentation
---
Two Column Layout
-------
\begin{columns}
\begin{column}{0.48\textwidth}
This slide has two columns
\end{column}
\begin{column}{0.48\textwidth}
If I put any code in here I get an error, see
https://support.rstudio.com/hc/communities/public/questions/202717656-Can-we-have-columns-in-rmarkdown-beamer-presentations-
\end{column}
\end{columns}
看起来像常规的Rnw LaTeX doc是获取列的最佳方式,如果你想使用LaTex,而不是这个降价混合(参见两列beamer / sweave slide with grid graphic )
在上述所有情况中,图像可以放在一列中。
slidify网站有关于在这里列出两列的说明: http ://slidify.org/customize.html但是不清楚要进入assets / layouts文件夹以使其工作
我现在拥有的是一个合理的解决方案,至少应该适用于基于ioslides
的解决方案,也许(?)适用于其他基于HTML5的格式。 从这里开始,我补充道
<style>
div#before-column p.forceBreak {
break-before: column;
}
div#after-column p.forceBreak {
break-after: column;
}
</style>
到我的文件的开头; 然后在{.columns-2}
的幻灯片中放置<p class="forceBreak"></p>
在该点打破列,例如
## Latin hypercube sampling {.columns-2}
- sample evenly, randomly across (potentially many) uncertain parameters
<p class="forceBreak"></p>
![](LHScrop.png)
[User:Saittam, Wikipedia](https://commons.wikimedia.org/wiki/File:LHSsampling.png#/media/File:LHSsampling.png)
可能有更好的方法,但这不是太痛苦。
@ChrisMerkord在评论中指出
.forceBreak { -webkit-column-break-after: always; break-after: column; }
工作(我还没有测试......)
我从这里得到了一个想法,基本的解决方案是:
### Function *inner_join*
. . .
`<div style="float: left; width: 50%;">`
``` {r, echo = FALSE, results = 'markup', eval = TRUE}
kable(cbind(A,B))
```
`</div>`
`<div style="float: right; width: 50%;">`
```{r, echo = TRUE, results = 'markup', eval = TRUE}
inner_join(A,B, by="C")
```
`</div>`
有关投影仪错误的解决方法 。
简而言之:错误与pandoc转换引擎有关,它将\\begin{...}
和\\end{...}
视为TeX 。 通过为yaml标头中的begin{column}
和end{column}
提供新定义,可以避免这种情况。
创建mystyle.tex并在那里写:
\def\begincols{\begin{columns}}
\def\begincol{\begin{column}}
\def\endcol{\end{column}}
\def\endcols{\end{columns}}
在Rmd文件中使用这些新定义
---
output:
beamer_presentation:
includes:
in_header: mystyle.tex
---
Two Column Layout
-------
\begincols
\begincol{.48\textwidth}
This slide has two columns.
\endcol
\begincol{.48\textwidth}
```{r}
#No error here i can run any r code
plot(cars)
```
\endcol
\endcols
到目前为止,我还没有能够做的比黑客的标记我自己的一点在上面更好的rmd
格式:我打电话给我的源文件rmd0
并运行,包括这样的脚本sed
珍闻要翻译成rmd
之前调用knit
:
sed -e 's/BEGIN2COLS\(.*\)/<table><tr><td style="vertical-align:top; width=50%" \1>/' \
-e 's/SWITCH2COLS/<\/td><td style="vertical-align:top">/' \
-e 's/END2COLS/<\/td><\/tr><\/table>/' ...
有几个原因我不喜欢这个。 (1)它是丑陋和特殊目的,我没有一个特别好的方法来允许可选参数(例如列的相对宽度,对齐等)。 (2)必须针对每种输出格式进行调整(例如,如果我想要LaTeX / beamer输出,我需要替换\\begin{columns}\\begin{column}{5cm} ... \\end{column}\\begin{column}{5cm} ... \\end{column}\\end{columns}
(因为事实证明我想在制作LaTeX格式的讲义时忽略两列格式,所以它更容易一点,但它仍然是丑陋)。
Slidify可能是答案。
您可以使用fenced_divs
表示法或:::
来创建列或“两个内容布局”。 另请参阅此页面以了解有关表示法的更多信息。
## Slide With Image Left
::: columns
:::: column
left
::::
:::: column
right
```{r your-chunk-name, echo=FALSE, fig.cap="your-caption-name"}
knitr::include_graphics("your/figure/path/to/the-image.pdf")
#The figure will appear on the right side of the slide...
```
::::
:::
由于支持符号的pandoc 2+
是在RStudio v1.2+
,因此您可能需要首先安装RStudio v1.2+
。 安装很简单(至少在我的情况下); 只需下载并安装RStudio v1.2+
。 在安装过程中,计算机上的旧版RStudio
将被替换为新版本,而无需手动卸载。
即使您使用beamer_presentation
选项编织.Rmd
文件,以及创建HTML幻灯片时,也可以使用:::
表示法。 因此,我们不必在一个文件中混合使用markdown和LaTeX表示法,也不必再添加其他代码:只需在编织其他.Rmd
使用其他选项编织文件。
不是直接的解决方案,但是Yihui的Xaringan
软件包https://github.com/yihui/xaringan/适合我。 它基于remark.js
。 在默认模板中,您可以使用.pull-left[]
和.pull-right[]
。 示例: https : //slides.yihui.name/xaringan/#15 。 您只需要对现有的.rmd
文件进行最小调整。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.