Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Inline R code in YAML for rmarkdown doesn't run

Tags:

r

r-markdown

I'm trying to run inline R code in the YAML front matter before getting rmarkdown to run the file. However it isn't working for me. Here's an example:

---
title: "**Title**"
classoption: xcolor=dvipsnames
output:
  beamer_presentation:
      slide_level: 2
      pandoc_args: [
        "--bibliography", "`r paste('path/to/bib')`"
        ]
---

<!-- slide 1 -->
## Intro ##

Which throws an error:

pandoc-citeproc: could not find `r paste('path/to/bib')`

This is a simple example, but highlights my main problem. How do I get rmarkdown to run the inline R code in the YAML front matter?

It is a similar problem to these questions:

  • Manipulate RMarkdown metadata from within R code chunks
  • YAML current date in rmarkdown
like image 408
Luke W. Johnston Avatar asked Sep 17 '15 18:09

Luke W. Johnston


People also ask

How do I run a r Markdown in a script?

You can call External r markdown page from r script using render function. Syntax: rmarkdown::render(rmd_file, output_type, output_file_name, knit options,....)

What is the difference between Markdown and rmarkdown?

R Markdown is an extension of the markdown syntax. R Markdown files are plain text files that typically have the file extension . Rmd . They are written using an extension of markdown syntax that enables R code to be embedded in them in a way which can later be executed.


1 Answers

This is how I solved this. I knit from RStudio. Curiously, I had to use one solution for the date and csl fields and a different solution for the bibliography field. !expr did not work in the date or csl lines (for me). And quoted r code didn't work in the bibliography line (for me). I have the bibliography and csl files in a package (inst/docs folder). rmarkdown files, which are not part of that package, use those.

---
title: "Title"
date: '`r format(Sys.time(), "%d %B, %Y")`'
output: html_document
bibliography: !expr system.file("docs", "my.bib", package = "MyPackage")
csl: '`r system.file("docs", "my.csl", package = "MyPackage")`'
---

# Introduction

Yada yada [@MyRef04].

# References

my.bib is the BibTex file with MyRef04. csl is the style file

This is a situation where one person maintains a package which has data, code, bibliography, etc. Others, potentially unknown to the package writer, install that package from GitHub and write or run rmarkdown files that use the package. The users almost certainly do not use Git or GitHub and I don't want them to have to download any extra files after installing the package from GitHub.

Update: After posting the above, I happened to install markdown from GitHub because I needed something in the development version. With version ‘1.7.5’ of rmarkdown on GitHub you can use r code in the bibliography line:

---
title: "Title"
date: '`r format(Sys.time(), "%d %B, %Y")`'
output: html_document
bibliography: '`r system.file("docs", "my.bib", package = "MyPackage")`'
csl: '`r system.file("docs", "my.csl", package = "MyPackage")`'
---

To install rmarkdown from GitHub

library(devtools)
install_github("rstudio/rmarkdown")
like image 58
Eli Holmes Avatar answered Oct 19 '22 22:10

Eli Holmes