Notes on Changing from Rmarkdown/Bookdown to Quarto (2024)

I’ve recently started transitioning my online book, rmarkdown for scientists from rmarkdown/bookdown to the new quarto. This will be a new book, called (perhaps not the most original name), “quarto for scientists”. Alison Hill recently wrote a great post, “We don’t talk about quarto” that led me to see the benefits, and also that this will be the new thing we will be using in the future.

Alison already covers this well in her post, and you should read that instead. But, somewhat briefly, here is my summary of quarto, and why you might care about it.

Quarto is a way to write literate programming documents. These are where you combine text and code together into a single document. Sound familiar? Well, yes, it is indeed like rmarkdown. Perhaps it might be easiest to look for comparisons with how they advertise themselves.

The README for rmarkdown states:

The rmarkdown package helps you create dynamic analysis documents that combine code, rendered output (such as figures), and prose. You bring your data, code, and ideas, and R Markdown renders your content into a polished document that can be used to:

  • Do data science interactively within the RStudio IDE,
  • Reproduce your analyses,
  • Collaborate and share code with others, and
  • Communicate your results with others.

R Markdown documents can be rendered to many output formats including HTML documents, PDFs, Word files, slideshows, and more, allowing you to focus on the content while R Markdown takes care of your presentation.

How is this different to quarto? Well, the README for quarto says:

Quarto is an open-source scientific and technical publishing system built on Pandoc. Quarto documents are authored using markdown, an easy to write plain text format.

In addition to the core capabilities of Pandoc, Quarto includes:

  1. Embedding code and output from Python, R, and JavaScript via integration with Jupyter, Knitr, and Observable.

  2. A variety of extensions to Pandoc markdown useful for technical writing including cross-references, sub-figures, layout panels, hoverable citations and footnotes, callouts, and more.

  3. A project system for rendering groups of documents at once, sharing options across documents, and producing aggregate output like websites and books.

  4. Authoring using a wide variety of editors and notebooks including JupyterLab, RStudio, and VS Code.

  5. A visual markdown editor that provides a productive writing interface for composing long-form documents.

Learn more about Quarto at https://quarto.org.

OK, but what does that mean?

Here’s the way I see it. rmarkdown is awesome, and it isn’t going anywhere. rmarkdown has been able to produce documents that use other software, such as python, bash, stan and many more. However, there are a few points of friction:

  1. You need to call it from R to use it. No problem for R users, but what if you use python? Or javascript? If you are a python user, using R to use python just might not be in your workflow.
  2. There are great packages that provide extensions, such as blogdown for blogs, bookdown for books, and xaringan for slides. However, there are differences between these systems that might cause stumbles. Each of these systems is an iteration towards something awesome, and it’s only natural they might be a little bit different.

quarto, instead of being an R package, is a separate piece of software, that you can call from the command line (terminal). This means other pieces of software can use it to create their own literate programming documents. Well, that’s my understanding.

Here are some not-particularly-well-drawn diagrams to illustrate this point.

In rmarkdown, we are working in rmarkdown, and that uses knitr to talk to R and handle the document generation:

Notes on Changing from Rmarkdown/Bookdown to Quarto (1)

But with quarto, we have this general interface, where quarto can talk to different programming languages. Not pictured, but the “R engine” is in fact, knitr:

Notes on Changing from Rmarkdown/Bookdown to Quarto (2)

Well, you might not need to! I cannot imagine rmarkdown going away any time soon. So, you definitely don’t need to change.

That being said. From what I can tell, quarto appears to be a lot more consistent. For example, instead of having a special _bookdown.yml file for your bookdown, which also needs a special _output.yml file, there is just now one single _quarto.yml file. It also means that there will likely be less pain if you need to change from a book to a website, to slides, to something else. So, I care because I like using the latest technology, and this seems like it will in the long run, be something that will be widely used. But I also work as a research software engineer, and caring about the latest and greatest tech is something that is on brand with the job. You don’t need to change to quarto. But it looks pretty cool.

Here are the rough steps I went through for going from rmarkdown to quarto

installing quarto + latest rstudio

I followed the instructions here to install quarto: https://quarto.org/docs/get-started/

As of 2022-04-08, it seems best to install the daily build of RStudio, which I did here: https://dailies.rstudio.com/

change filenames: filename.Rmd —> filename.qmd

I used this code to identify the files that ended with “.Rmd” and then renamed them to end with “.qmd”, which is the quarto extension.

library(fs)library(stringr)rmd_names <- dir_ls(path = ".", glob = "*.Rmd")qmd_names <- str_replace(string = rmd_names, pattern = "Rmd", replacement = "qmd")file_move(path = rmd_names, new_path = qmd_names)file_move(path = "_bookdown.yml", new_path = "_quarto.yml")

You can see this change in this commit of qmd4sci.

Change _bookdown.yml to _quarto.yml and remove _output.yml

I also needed to change most of the structure of _bookdown.yml, and to do so I followed the guidance of the book guide in quarto, as well as looking at two quarto books they have provided, “Hands on Programming with R”, and “Data Visualization Curriculum”.

One thing I also needed to do was to replace the chapter names I had listed in the chapter as :

  • “index.Rmd” –> “index.qmd”

  • “license.Rmd” -> “license.qmd”

et cetera.

I used this code to do that:

library(readr)library(stringr)quarto_yaml_rmd <- read_lines("_quarto.yml")quarto_yaml_qmd <- str_replace_all(string = quarto_yaml_rmd, pattern = "Rmd", replacement = "qmd")write_lines( x = quarto_yaml_qmd, file = "_quarto.yml")

Which you can see in this commit.

build? preview?

I then tried to click the nifty, “build” tab that appears in the environment pane in RStudio. But this didn’t work. So I turned to the terminal and typed:

quarto preview

And then I got some errors.

Specifically,

qmd4sci nick$ quarto previewPreparing to preview[ 1/23] index.qmdERROR: Validation of YAML front matter failed.ERROR: In file index.qmd(line 11, columns 13--15) Key colorlinks has value yes, which must be `true` or `false`✖ The value yes is a string.ℹ The error happened in location colorlinks.ℹ Quarto uses YAML 1.2, which interprets booleans strictly.ℹ Try using true instead.

Which is actually quite helpful!

This tells me that I need to look at the index.qmd file, which had a bunch of YAML metadata in it like so:

--- title: "RMarkdown for Scientists"author: "Nicholas Tierney"date: "2022-04-11"knit: "bookdown::render_book"description: "A book created for a 3 hour workshop on rmarkdown"documentclass: krantzsite: bookdown::bookdown_sitebibliography: [book.bib, packages.bib]biblio-style: apalikecolorlinks: yesfontsize: 12ptmonofont: "Source Code Pro"monofontoptions: "Scale=0.7"link-citations: yesurl: 'https\://rmd4sci.njtierney.com/'---

It turns out I could remove this, and put most of it into the _quarto.yml file. I think this is a nice example of how quarto can help simplify things. It used to be a thing that you had to have some file that gave some extra metadata, or at least, it seemed like the best thing to do at the time that I wrote that book. But now all of that stuff goes into _quarto.yml.

(Also, really cool thing about using the latest RStudio daily build that I noticed, is that you get tab-completion when you are inside the YAML. So you can start exploring options for things to add! Neat. But perhaps that was already a feature in regular-rstudio and I didn’t notice.)

Anyway, these changes are detailed in this commit.

repeat: build? preview?

The build tab doesn’t seem to work for me in RStudio, since it seems to call rmarkdown by default and that doesn’t really work.

Typing quarto preview into my terminal I get something like this:

Notes on Changing from Rmarkdown/Bookdown to Quarto (3)

Rather neatly, quarto appears to re render whenever I save files, which is pretty awesome!

What next?

I’ll need to update the book to change references from rmarkdown to quarto, as well as change all the details of rmarkdown to quarto, and all the new quarto features. Which is, well, probably a lot.

Notes on Changing from Rmarkdown/Bookdown to Quarto (2024)
Top Articles
Memphis Tennessee Craigslist Free Stuff
Unionsmarkenrecht: Markenrecherche vor Markenanmeldung EU-Markenrecht, EU-Markenanmeldung, EU-Markenverwaltung, EU-Markenüberwachung, EU-Markenverletzung - Markenanwälte/ European Trademark Attorneys
Fan Van Ari Alectra
Www.metaquest/Device Code
Hawkeye 2021 123Movies
Mylaheychart Login
Caliber Collision Burnsville
Niche Crime Rate
Itziar Atienza Bikini
Craigslist Missoula Atv
Menus - Sea Level Oyster Bar - NBPT
Anotherdeadfairy
How To Tighten Lug Nuts Properly (Torque Specs) | TireGrades
Jailfunds Send Message
Hwy 57 Nursery Michie Tn
Jackass Golf Cart Gif
Marlene2295
Amazing Lash Bay Colony
Issue Monday, September 23, 2024
Chicago Pd Rotten Tomatoes
Gideon Nicole Riddley Read Online Free
Plato's Closet Mansfield Ohio
Desirulez.tv
Haley Gifts :: Stardew Valley
W B Crumel Funeral Home Obituaries
The 50 Best Albums of 2023
Laff Tv Passport
How are you feeling? Vocabulary & expressions to answer this common question!
Hindilinks4U Bollywood Action Movies
Michael Jordan: A timeline of the NBA legend
The Banshees Of Inisherin Showtimes Near Reading Cinemas Town Square
Final Jeopardy July 25 2023
Timberwolves Point Guard History
Doordash Promo Code Generator
Locate phone number
Frigidaire Fdsh450Laf Installation Manual
Wilson Tire And Auto Service Gambrills Photos
Grand Valley State University Library Hours
Southwest Airlines Departures Atlanta
White County
705 Us 74 Bus Rockingham Nc
Pickwick Electric Power Outage
Steam Input Per Game Setting
Definition of WMT
Strange World Showtimes Near Atlas Cinemas Great Lakes Stadium 16
Aaca Not Mine
Free Carnival-themed Google Slides & PowerPoint templates
March 2023 Wincalendar
Estes4Me Payroll
Festival Gas Rewards Log In
Edict Of Force Poe
Stone Eater Bike Park
Latest Posts
Article information

Author: Nathanael Baumbach

Last Updated:

Views: 6109

Rating: 4.4 / 5 (75 voted)

Reviews: 90% of readers found this page helpful

Author information

Name: Nathanael Baumbach

Birthday: 1998-12-02

Address: Apt. 829 751 Glover View, West Orlando, IN 22436

Phone: +901025288581

Job: Internal IT Coordinator

Hobby: Gunsmithing, Motor sports, Flying, Skiing, Hooping, Lego building, Ice skating

Introduction: My name is Nathanael Baumbach, I am a fantastic, nice, victorious, brave, healthy, cute, glorious person who loves writing and wants to share my knowledge and understanding with you.