##// END OF EJS Templates
move @annotate to py3compat
move @annotate to py3compat

File last commit:

r13353:0ca701d5
r15146:9bd3a1d4
Show More
nbpy.py
151 lines | 5.2 KiB | text/x-python | PythonLexer
Brian E. Granger
More review changes....
r4609 """Read and write notebooks as regular .py files.
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 COPYING, distributed as part of this software.
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
# Imports
#-----------------------------------------------------------------------------
Brian E. Granger
Adding nbformat subpackage.
r4392
Thomas Kluyver
Strip out encoding declaration when loading notebook.
r5739 import re
Thomas Kluyver
Replace references to unicode and basestring
r13353 from IPython.utils.py3compat import unicode_type
Brian E. Granger
Initial draft of more formal notebook format....
r4401 from .rwbase import NotebookReader, NotebookWriter
Brian E. Granger
New .py notebook format implemented.
r4536 from .nbbase import new_code_cell, new_text_cell, new_worksheet, new_notebook
Brian E. Granger
Adding nbformat subpackage.
r4392
Brian E. Granger
More review changes....
r4609 #-----------------------------------------------------------------------------
# Code
#-----------------------------------------------------------------------------
Brian E. Granger
Adding nbformat subpackage.
r4392
Thomas Kluyver
Use emacs-recognised encoding declaration.
r5745 _encoding_declaration_re = re.compile(r"^#.*coding[:=]\s*([-\w.]+)")
Thomas Kluyver
Strip out encoding declaration when loading notebook.
r5739
Brian E. Granger
Improvements to file uploaded, mime types and .py reader....
r4493 class PyReaderError(Exception):
pass
Brian E. Granger
Adding nbformat subpackage.
r4392 class PyReader(NotebookReader):
Brian E. Granger
Initial draft of more formal notebook format....
r4401 def reads(self, s, **kwargs):
Brian E. Granger
Full versioning added to nbformat.
r4406 return self.to_notebook(s,**kwargs)
def to_notebook(self, s, **kwargs):
Brian E. Granger
Adding nbformat subpackage.
r4392 lines = s.splitlines()
cells = []
cell_lines = []
Brian E. Granger
New .py notebook format implemented.
r4536 state = u'codecell'
Brian E. Granger
Adding nbformat subpackage.
r4392 for line in lines:
Thomas Kluyver
Strip out encoding declaration when loading notebook.
r5739 if line.startswith(u'# <nbformat>') or _encoding_declaration_re.match(line):
Brian E. Granger
Created new notebook magic that can export/convert notebooks....
r4520 pass
elif line.startswith(u'# <codecell>'):
Brian E. Granger
New .py notebook format implemented.
r4536 cell = self.new_cell(state, cell_lines)
if cell is not None:
cells.append(cell)
state = u'codecell'
cell_lines = []
Bernardo B. Marques
remove all trailling spaces
r4872 elif line.startswith(u'# <htmlcell>'):
Brian E. Granger
New .py notebook format implemented.
r4536 cell = self.new_cell(state, cell_lines)
if cell is not None:
cells.append(cell)
state = u'htmlcell'
cell_lines = []
elif line.startswith(u'# <markdowncell>'):
cell = self.new_cell(state, cell_lines)
if cell is not None:
cells.append(cell)
state = u'markdowncell'
Brian E. Granger
Full versioning added to nbformat.
r4406 cell_lines = []
Brian E. Granger
Adding nbformat subpackage.
r4392 else:
cell_lines.append(line)
Brian E. Granger
New .py notebook format implemented.
r4536 if cell_lines and state == u'codecell':
cell = self.new_cell(state, cell_lines)
if cell is not None:
cells.append(cell)
Brian E. Granger
Adding nbformat subpackage.
r4392 ws = new_worksheet(cells=cells)
nb = new_notebook(worksheets=[ws])
return nb
Brian E. Granger
New .py notebook format implemented.
r4536 def new_cell(self, state, lines):
if state == u'codecell':
input = u'\n'.join(lines)
input = input.strip(u'\n')
if input:
return new_code_cell(input=input)
elif state == u'htmlcell':
text = self._remove_comments(lines)
if text:
return new_text_cell(u'html',source=text)
elif state == u'markdowncell':
text = self._remove_comments(lines)
if text:
return new_text_cell(u'markdown',source=text)
def _remove_comments(self, lines):
new_lines = []
for line in lines:
if line.startswith(u'#'):
new_lines.append(line[2:])
else:
new_lines.append(line)
text = u'\n'.join(new_lines)
text = text.strip(u'\n')
return text
Brian E. Granger
Improvements to file uploaded, mime types and .py reader....
r4493 def split_lines_into_blocks(self, lines):
Brian E. Granger
Created new notebook magic that can export/convert notebooks....
r4520 if len(lines) == 1:
yield lines[0]
raise StopIteration()
Brian E. Granger
Improvements to file uploaded, mime types and .py reader....
r4493 import ast
source = '\n'.join(lines)
code = ast.parse(source)
starts = [x.lineno-1 for x in code.body]
for i in range(len(starts)-1):
yield '\n'.join(lines[starts[i]:starts[i+1]]).strip('\n')
yield '\n'.join(lines[starts[-1]:]).strip('\n')
Brian E. Granger
Adding nbformat subpackage.
r4392
class PyWriter(NotebookWriter):
Brian E. Granger
Initial draft of more formal notebook format....
r4401 def writes(self, nb, **kwargs):
Thomas Kluyver
Use emacs-recognised encoding declaration.
r5745 lines = [u'# -*- coding: utf-8 -*-']
Thomas Kluyver
Tweak to notebook -> .py export, at Fernando's suggestion.
r5742 lines.extend([u'# <nbformat>2</nbformat>',''])
Brian E. Granger
Initial draft of more formal notebook format....
r4401 for ws in nb.worksheets:
for cell in ws.cells:
Brian E. Granger
New .py notebook format implemented.
r4536 if cell.cell_type == u'code':
input = cell.get(u'input')
Brian E. Granger
Massive work on the notebook document format....
r4484 if input is not None:
lines.extend([u'# <codecell>',u''])
lines.extend(input.splitlines())
Brian E. Granger
New .py notebook format implemented.
r4536 lines.append(u'')
elif cell.cell_type == u'html':
input = cell.get(u'source')
if input is not None:
lines.extend([u'# <htmlcell>',u''])
lines.extend([u'# ' + line for line in input.splitlines()])
lines.append(u'')
elif cell.cell_type == u'markdown':
input = cell.get(u'source')
if input is not None:
lines.extend([u'# <markdowncell>',u''])
lines.extend([u'# ' + line for line in input.splitlines()])
lines.append(u'')
Brian E. Granger
Full versioning added to nbformat.
r4406 lines.append('')
Thomas Kluyver
Replace references to unicode and basestring
r13353 return unicode_type('\n'.join(lines))
Brian E. Granger
Adding nbformat subpackage.
r4392
_reader = PyReader()
_writer = PyWriter()
reads = _reader.reads
read = _reader.read
Brian E. Granger
Full versioning added to nbformat.
r4406 to_notebook = _reader.to_notebook
Brian E. Granger
Adding nbformat subpackage.
r4392 write = _writer.write
writes = _writer.writes
Brian E. Granger
Full versioning added to nbformat.
r4406