.. _format: ********************************************************************************* Markdown notebook format ********************************************************************************* .. contents:: .. index:: notebook format, markdown Although GraphTerm can read and write notebooks in the IPython (``.ipynb``) format, it natively saves notebooks using basic `Markdown `_ syntax, with support for the GitHub-style `fenced code extension `_. The notebook filenames have the extension ``.py.gnb.md`` for Python, ``.R.gnb.md`` for R and so on. The Markdown sequential text format has some advantages over the JSON format used for ``.ipynb`` files: - Notebooks may be easily viewed using standard Markup rendering software and will automatically render on GitHub (`example `_). - Notebooks can be easily modified using standard text editors, moving around blocks of code and markup. - Notebooks can be split and concatenated at block boundaries, like text files (e.g. ``cat a.py.gnb.md b.py.gnb.md > c.py.gnb.md``) Markup cells are simply saved as Markdown text in the notebook file. This can include raw HTML, figures, or program statements. Triple dashes (``---``) can be used as page breaks to denote section/slide boundaries. Program statements occurring within a markup cell must be indented by at least four spaces. The data URIs for all figures are saved at the end of the file, making it easier to view the notebook cell content. Code cells are saved as fenced code blocks in the notebook file, e.g.:: ```python print "Hello World" ``` Output text resulting from running the code is saved in fenced code blocks of type ``output``:: ```output Hello ``` Figures resulting from code execution are distinguished by the prefix ``output-`` in their name, e.g.:: ![image][output-fig1-test.py] Multiple ``output`` text blocks and output figures, separated by blank lines, are considered as representing the cumulative output from executing the previous code block. To create a progressively fillable notebook, ``output`` blocks and figures are converted to ``expect`` blocks and figures. Here's an example notebook file:: # A sample GraphTerm notebook file in Markdown format --- ## Part I Write a function ``abs_add`` that returns the sum of the absolute values of two numbers. Test the function. ```python # Part 1: Define the function abs_add def abs_add(a, b): return abs(a) + abs(b) # Testing function abs_add print abs_add(3, -4) ``` ```output 7 ``` --- ## Part II Write some code to create a simple line plot with a title using the ``pylab`` module. ```python x = [1, 2, 3, 4] y = [1, 4, 9, 16] title = "Plot of y = x-squared" import pylab # Part 2: Plotting code pylab.plot(x, y) pylab.title(title) ``` ```output ``` ![image][output-fig1-Progressive-demo.py] [output-fig1-Progressive-demo.py]: ...