| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200 |
- """The basic dict based notebook format.
- The Python representation of a notebook is a nested structure of
- dictionary subclasses that support attribute access.
- The functions in this module are merely
- helpers to build the structs in the right form.
- Authors:
- * Brian Granger
- """
- # -----------------------------------------------------------------------------
- # Copyright (C) 2008-2011 The IPython Development Team
- #
- # Distributed under the terms of the BSD License. The full license is in
- # the file LICENSE, distributed as part of this software.
- # -----------------------------------------------------------------------------
- # -----------------------------------------------------------------------------
- # Imports
- # -----------------------------------------------------------------------------
- from __future__ import annotations
- from nbformat._struct import Struct
- # -----------------------------------------------------------------------------
- # Code
- # -----------------------------------------------------------------------------
- class NotebookNode(Struct):
- """A notebook node object."""
- def from_dict(d):
- """Create notebook node(s) from a value."""
- if isinstance(d, dict):
- newd = NotebookNode()
- for k, v in d.items():
- newd[k] = from_dict(v)
- return newd
- if isinstance(d, (tuple, list)):
- return [from_dict(i) for i in d]
- return d
- def new_output(
- output_type=None,
- output_text=None,
- output_png=None,
- output_html=None,
- output_svg=None,
- output_latex=None,
- output_json=None,
- output_javascript=None,
- output_jpeg=None,
- prompt_number=None,
- etype=None,
- evalue=None,
- traceback=None,
- ):
- """Create a new code cell with input and output"""
- output = NotebookNode()
- if output_type is not None:
- output.output_type = str(output_type)
- if output_type != "pyerr":
- if output_text is not None:
- output.text = str(output_text)
- if output_png is not None:
- output.png = bytes(output_png)
- if output_jpeg is not None:
- output.jpeg = bytes(output_jpeg)
- if output_html is not None:
- output.html = str(output_html)
- if output_svg is not None:
- output.svg = str(output_svg)
- if output_latex is not None:
- output.latex = str(output_latex)
- if output_json is not None:
- output.json = str(output_json)
- if output_javascript is not None:
- output.javascript = str(output_javascript)
- if output_type == "pyout" and prompt_number is not None:
- output.prompt_number = int(prompt_number)
- if output_type == "pyerr":
- if etype is not None:
- output.etype = str(etype)
- if evalue is not None:
- output.evalue = str(evalue)
- if traceback is not None:
- output.traceback = [str(frame) for frame in list(traceback)]
- return output
- def new_code_cell(
- input=None,
- prompt_number=None,
- outputs=None,
- language="python",
- collapsed=False,
- ):
- """Create a new code cell with input and output"""
- cell = NotebookNode()
- cell.cell_type = "code"
- if language is not None:
- cell.language = str(language)
- if input is not None:
- cell.input = str(input)
- if prompt_number is not None:
- cell.prompt_number = int(prompt_number)
- if outputs is None:
- cell.outputs = []
- else:
- cell.outputs = outputs
- if collapsed is not None:
- cell.collapsed = bool(collapsed)
- return cell
- def new_text_cell(cell_type, source=None, rendered=None):
- """Create a new text cell."""
- cell = NotebookNode()
- if source is not None:
- cell.source = str(source)
- if rendered is not None:
- cell.rendered = str(rendered)
- cell.cell_type = cell_type
- return cell
- def new_worksheet(name=None, cells=None):
- """Create a worksheet by name with with a list of cells."""
- ws = NotebookNode()
- if name is not None:
- ws.name = str(name)
- if cells is None:
- ws.cells = []
- else:
- ws.cells = list(cells)
- return ws
- def new_notebook(metadata=None, worksheets=None):
- """Create a notebook by name, id and a list of worksheets."""
- nb = NotebookNode()
- nb.nbformat = 2
- if worksheets is None:
- nb.worksheets = []
- else:
- nb.worksheets = list(worksheets)
- if metadata is None:
- nb.metadata = new_metadata()
- else:
- nb.metadata = NotebookNode(metadata)
- return nb
- def new_metadata(
- name=None,
- authors=None,
- license=None,
- created=None,
- modified=None,
- gistid=None,
- ):
- """Create a new metadata node."""
- metadata = NotebookNode()
- if name is not None:
- metadata.name = str(name)
- if authors is not None:
- metadata.authors = list(authors)
- if created is not None:
- metadata.created = str(created)
- if modified is not None:
- metadata.modified = str(modified)
- if license is not None:
- metadata.license = str(license)
- if gistid is not None:
- metadata.gistid = str(gistid)
- return metadata
- def new_author(name=None, email=None, affiliation=None, url=None):
- """Create a new author."""
- author = NotebookNode()
- if name is not None:
- author.name = str(name)
- if email is not None:
- author.email = str(email)
- if affiliation is not None:
- author.affiliation = str(affiliation)
- if url is not None:
- author.url = str(url)
- return author
|