Skip to main content

Convert between IPython/Jupyter notebooks and RMarkdown

Project description

ipyrmd
======

Convert between IPython/Jupyter notebooks and R Markdown documents
------------------------------------------------------------------

This script provides conversion in both directions between the [IPython](https://github.com/ipython/ipython) [notebook format](https://ipython.org/ipython-doc/3/notebook/nbformat.html) (JSON with separate markdown and code) and the [R Markdown](https://github.com/rstudio/rmarkdown) [format](http://rmarkdown.rstudio.com) (markdown text with annotated code blocks). Conversion to and from plain R files with markdown embedded in [knitr](http://yihui.name/knitr/)-style comments (`#' markdown`) is also supported.

It only really makes sense to use it with IPython notebooks using the IPython [R kernel](http://github.com/IRkernel/IRkernel), but will work with any type of code if you insist.

Conversion should produce useful output, but is not completely lossless:

* Inline code blocks in R Markdown (`r somecode`) are currently ignored (they remain as markdown text). Inserting code blocks for them would be a possible extension but since the main use for such blocks is to display an output value I assume ignoring them should not usually change program flow.
* The YAML header used in R Markdown does not have a functional equivalent in IPython. The contents of the header are stored in the IPython notebook metadata dictionary (as `Rmd_header`) for round-trip conversion, but are not otherwise used.
* Chunk options for R Markdown (```` ```{r, foo=bar}````) also do not (currently) have any functional equivalent in the IPython notebook. The option string (as text) is stored in the cell metadata (as `Rmd_chunk_options`) for round-trip conversion.
* Since whitespace is significant in markdown, we attempt to maintain blank lines within code and markdown blocks, but the boundaries between code and markdown may not be exactly reproduced (you may get extra blank lines).
* The IPython notebook may contain both text and rich output, but there is no way to keep this for R Markdown - you will need to re-knit the document.

Usage
-----

`python3`, `nbformat` and `pyyaml` are required.

ipyrmd [--to R|Rmd|ipynb] [--from R|Rmd|ipynb] [-y] [-o outfile] infile

By default the output filename and mode of conversion is determined from the input filename. Notebooks are converted by default to RMarkdown unless you specify R output.

Install
-------

pip3 install [--user] [--upgrade] ipyrmd

Alternatives, it can be installed manually by downloading the archive, extracting it then running `python3 setup.py install --user`. This should install the `ipyrmd` script in your local bin directory (probably `~/.local/bin`).

TODO
----

* Options for how to handle inline R blocks
* Consider using nbconvert machinery for ipynb -> Rmd conversion
* Consider whether any chunk options can be emulated with IRdisplay calls
* Check IPython API compatibility between IPython and Jupyter
* De-duplicate code between R and Rmd methods

History
-------

* 0.1 (2015-05-27) Initial release
* 0.2 (2015-05-29) Re-structure as a python library providing script `ipyrmd`
* 0.3 (2015-06-09) Add support for R files with markdown embedded in #' comments
* 0.4 (2016-06-01) Added a test suite and fixed a number of round-trip bugs
* 0.4.2 (2016-06-29) Fix missing README causing setup errors (ipyrmd#3)
* 0.4.3 (2017-10-09) Fix installation using requirements.txt (ipyrmd#4)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ipyrmd-0.4.3.tar.gz (6.8 kB view details)

Uploaded Source

File details

Details for the file ipyrmd-0.4.3.tar.gz.

File metadata

  • Download URL: ipyrmd-0.4.3.tar.gz
  • Upload date:
  • Size: 6.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for ipyrmd-0.4.3.tar.gz
Algorithm Hash digest
SHA256 5e9fa7682b43f6a1cef9ac34209cd0fb97949926cc4873193a5ce8ffb3503e23
MD5 28da1eb2b367f9413b5634672fc4a42e
BLAKE2b-256 5a17a80f6023af94849954fb053f9a65e530dc84845a3f498c28ee250e5a4561

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page