| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- """The main API for the v2 notebook format.
- 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
- import os
- from .convert import downgrade, upgrade
- from .nbbase import (
- NotebookNode,
- new_author,
- new_code_cell,
- new_metadata,
- new_notebook,
- new_output,
- new_text_cell,
- new_worksheet,
- )
- from .nbjson import reads as read_json
- from .nbjson import reads as reads_json
- from .nbjson import to_notebook as to_notebook_json
- from .nbjson import writes as write_json
- from .nbjson import writes as writes_json
- from .nbpy import reads as read_py
- from .nbpy import reads as reads_py
- from .nbpy import to_notebook as to_notebook_py
- from .nbpy import writes as write_py
- from .nbpy import writes as writes_py
- # Implementation removed, vulnerable to DoS attacks
- from .nbxml import reads as read_xml
- from .nbxml import reads as reads_xml
- from .nbxml import to_notebook as to_notebook_xml
- # -----------------------------------------------------------------------------
- # Code
- # -----------------------------------------------------------------------------
- nbformat = 2
- nbformat_minor = 0
- def parse_filename(fname):
- """Parse a notebook filename.
- This function takes a notebook filename and returns the notebook
- format (json/py) and the notebook name. This logic can be
- summarized as follows:
- * notebook.ipynb -> (notebook.ipynb, notebook, json)
- * notebook.json -> (notebook.json, notebook, json)
- * notebook.py -> (notebook.py, notebook, py)
- * notebook -> (notebook.ipynb, notebook, json)
- Parameters
- ----------
- fname : unicode
- The notebook filename. The filename can use a specific filename
- extension (.ipynb, .json, .py) or none, in which case .ipynb will
- be assumed.
- Returns
- -------
- (fname, name, format) : (unicode, unicode, unicode)
- The filename, notebook name and format.
- """
- basename, ext = os.path.splitext(fname) # noqa: PTH122
- if ext in [".ipynb", ".json"]:
- format_ = "json"
- elif ext == ".py":
- format_ = "py"
- else:
- basename = fname
- fname = fname + ".ipynb"
- format_ = "json"
- return fname, basename, format_
|