nbjson.py
67 lines
| 1.8 KiB
| text/x-python
|
PythonLexer
MinRK
|
r18573 | """Read and write notebooks in JSON format.""" | ||
MinRK
|
r18568 | |||
MinRK
|
r18573 | # Copyright (c) IPython Development Team. | ||
# Distributed under the terms of the Modified BSD License. | ||||
MinRK
|
r18568 | |||
import copy | ||||
import json | ||||
MinRK
|
r18573 | from IPython.utils import py3compat | ||
MinRK
|
r18568 | from .nbbase import from_dict | ||
from .rwbase import ( | ||||
MinRK
|
r18581 | NotebookReader, NotebookWriter, rejoin_lines, split_lines, strip_transient | ||
MinRK
|
r18568 | ) | ||
class BytesEncoder(json.JSONEncoder): | ||||
"""A JSON encoder that accepts b64 (and other *ascii*) bytestrings.""" | ||||
def default(self, obj): | ||||
if isinstance(obj, bytes): | ||||
return obj.decode('ascii') | ||||
return json.JSONEncoder.default(self, obj) | ||||
class JSONReader(NotebookReader): | ||||
def reads(self, s, **kwargs): | ||||
MinRK
|
r18606 | """Read a JSON string into a Notebook object""" | ||
MinRK
|
r18568 | nb = json.loads(s, **kwargs) | ||
nb = self.to_notebook(nb, **kwargs) | ||||
return nb | ||||
def to_notebook(self, d, **kwargs): | ||||
MinRK
|
r18606 | """Convert a disk-format notebook dict to in-memory NotebookNode | ||
handles multi-line values as strings, scrubbing of transient values, etc. | ||||
""" | ||||
nb = from_dict(d) | ||||
nb = rejoin_lines(nb) | ||||
MinRK
|
r18581 | nb = strip_transient(nb) | ||
return nb | ||||
MinRK
|
r18568 | |||
class JSONWriter(NotebookWriter): | ||||
def writes(self, nb, **kwargs): | ||||
MinRK
|
r18606 | """Serialize a NotebookNode object as a JSON string""" | ||
MinRK
|
r18568 | kwargs['cls'] = BytesEncoder | ||
kwargs['indent'] = 1 | ||||
kwargs['sort_keys'] = True | ||||
kwargs['separators'] = (',',': ') | ||||
MinRK
|
r18581 | # don't modify in-memory dict | ||
nb = copy.deepcopy(nb) | ||||
MinRK
|
r18568 | if kwargs.pop('split_lines', True): | ||
MinRK
|
r18581 | nb = split_lines(nb) | ||
nb = strip_transient(nb) | ||||
MinRK
|
r18568 | return py3compat.str_to_unicode(json.dumps(nb, **kwargs), 'utf-8') | ||
_reader = JSONReader() | ||||
_writer = JSONWriter() | ||||
reads = _reader.reads | ||||
read = _reader.read | ||||
to_notebook = _reader.to_notebook | ||||
write = _writer.write | ||||
writes = _writer.writes | ||||