You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			71 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Python
		
	
			
		
		
	
	
			71 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Python
		
	
"""Read and write notebooks in JSON format."""
 | 
						|
 | 
						|
# Copyright (c) IPython Development Team.
 | 
						|
# Distributed under the terms of the Modified BSD License.
 | 
						|
from __future__ import annotations
 | 
						|
 | 
						|
import copy
 | 
						|
import json
 | 
						|
 | 
						|
from nbformat.notebooknode import from_dict
 | 
						|
 | 
						|
from .rwbase import NotebookReader, NotebookWriter, rejoin_lines, split_lines, strip_transient
 | 
						|
 | 
						|
 | 
						|
class BytesEncoder(json.JSONEncoder):
 | 
						|
    """A JSON encoder that accepts b64 (and other *ascii*) bytestrings."""
 | 
						|
 | 
						|
    def default(self, obj):
 | 
						|
        """Get the default value of an object."""
 | 
						|
        if isinstance(obj, bytes):
 | 
						|
            return obj.decode("ascii")
 | 
						|
        return json.JSONEncoder.default(self, obj)
 | 
						|
 | 
						|
 | 
						|
class JSONReader(NotebookReader):
 | 
						|
    """A JSON notebook reader."""
 | 
						|
 | 
						|
    def reads(self, s, **kwargs):
 | 
						|
        """Read a JSON string into a Notebook object"""
 | 
						|
        nb = json.loads(s, **kwargs)
 | 
						|
        nb = self.to_notebook(nb, **kwargs)
 | 
						|
        return nb  # noqa: RET504
 | 
						|
 | 
						|
    def to_notebook(self, d, **kwargs):
 | 
						|
        """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)
 | 
						|
        nb = strip_transient(nb)
 | 
						|
        return nb  # noqa: RET504
 | 
						|
 | 
						|
 | 
						|
class JSONWriter(NotebookWriter):
 | 
						|
    """A JSON notebook writer."""
 | 
						|
 | 
						|
    def writes(self, nb, **kwargs):
 | 
						|
        """Serialize a NotebookNode object as a JSON string"""
 | 
						|
        kwargs["cls"] = BytesEncoder
 | 
						|
        kwargs["indent"] = 1
 | 
						|
        kwargs["sort_keys"] = True
 | 
						|
        kwargs["separators"] = (",", ": ")
 | 
						|
        kwargs.setdefault("ensure_ascii", False)
 | 
						|
        # don't modify in-memory dict
 | 
						|
        nb = copy.deepcopy(nb)
 | 
						|
        if kwargs.pop("split_lines", True):
 | 
						|
            nb = split_lines(nb)
 | 
						|
        nb = strip_transient(nb)
 | 
						|
        return json.dumps(nb, **kwargs)
 | 
						|
 | 
						|
 | 
						|
_reader = JSONReader()
 | 
						|
_writer = JSONWriter()
 | 
						|
 | 
						|
reads = _reader.reads
 | 
						|
read = _reader.read
 | 
						|
to_notebook = _reader.to_notebook
 | 
						|
write = _writer.write
 | 
						|
writes = _writer.writes
 |