diff --git a/nbconvert/exporters/html.py b/nbconvert/exporters/html.py index 89a3558e7..5c6f6c478 100644 --- a/nbconvert/exporters/html.py +++ b/nbconvert/exporters/html.py @@ -265,9 +265,8 @@ def from_notebook_node( # type:ignore[explicit-override, override] if cell.cell_type == "markdown": markdown_collection = markdown_collection + cell.source + "\n" - resources["tableofcontents"] = extract_titles_from_markdown_input(markdown_collection) - resources = self._init_resources(resources) + resources.update({"tableofcontents": extract_titles_from_markdown_input(markdown_collection)}) filter_data_type = WidgetsDataTypeFilter( notebook_metadata=self._nb_metadata, parent=self, resources=resources diff --git a/nbconvert/exporters/slides.py b/nbconvert/exporters/slides.py index e571a90c0..62a11402b 100644 --- a/nbconvert/exporters/slides.py +++ b/nbconvert/exporters/slides.py @@ -41,7 +41,7 @@ def preprocess(self, nb, resources=None): in_fragment = False - for index, cell in enumerate(nb.cells[first_slide_ix + 1 :], start=(first_slide_ix + 1)): + for index, cell in enumerate(nb.cells[first_slide_ix + 1:], start=(first_slide_ix + 1)): previous_cell = nb.cells[index - 1] # Slides are
elements in the HTML, subslides (the vertically diff --git a/nbconvert/exporters/templateexporter.py b/nbconvert/exporters/templateexporter.py index 6b1d66202..0f551b069 100644 --- a/nbconvert/exporters/templateexporter.py +++ b/nbconvert/exporters/templateexporter.py @@ -203,9 +203,8 @@ def default_config(self): enable_async = Bool(False, help="Enable Jinja async template execution").tag( affects_environment=True ) - include_tableofcontents = Bool(False, allow_none=True, help="Enable to include a table of contents").tag( - config=True, affects_template=True + config=True, affects_template=True ) _last_template_file = "" @@ -289,8 +288,7 @@ def _template_extension_default(self): ).tag(config=True) exclude_output = Bool( - False, - help="This allows you to exclude code cell outputs from all templates if set to True.", + False, help="This allows you to exclude code cell outputs from all templates if set to True.", ).tag(config=True) exclude_output_prompt = Bool( @@ -686,5 +684,3 @@ def _init_resources(self, resources): resources["deprecated"] = deprecated resources["include_tableofcontents"] = self.include_tableofcontents return resources - - diff --git a/nbconvert/filters/ansi.py b/nbconvert/filters/ansi.py index a9882e10e..ac91fc89f 100644 --- a/nbconvert/filters/ansi.py +++ b/nbconvert/filters/ansi.py @@ -197,7 +197,7 @@ def _ansi2anything(text, converter): pass # Invalid color specification else: pass # Not a color code - chunk, text = text[: m.start()], text[m.end() :] + chunk, text = text[: m.start()], text[m.end():] else: chunk, text = text, "" diff --git a/nbconvert/filters/citation.py b/nbconvert/filters/citation.py index 0db092a42..e078ceed0 100644 --- a/nbconvert/filters/citation.py +++ b/nbconvert/filters/citation.py @@ -42,7 +42,7 @@ def citation2latex(s): outtext = "" startpos = 0 for citation in parser.citelist: - outtext += s[startpos : citation[1]] + outtext += s[startpos: citation[1]] outtext += "\\cite{%s}" % citation[0] startpos = citation[2] if len(citation) == 3 else -1 outtext += s[startpos:] if startpos != -1 else "" diff --git a/nbconvert/filters/markdown_mistune.py b/nbconvert/filters/markdown_mistune.py index c1889f06e..9a9046e72 100644 --- a/nbconvert/filters/markdown_mistune.py +++ b/nbconvert/filters/markdown_mistune.py @@ -385,7 +385,7 @@ def _embed_image_or_attachment(self, src: str) -> str: attachment_prefix = "attachment:" if src.startswith(attachment_prefix): - name = src[len(attachment_prefix) :] + name = src[len(attachment_prefix):] if name not in self.attachments: msg = f"missing attachment: {name}" @@ -485,6 +485,7 @@ def render(self, source: str) -> str: """Render the HTML output for a Markdown source.""" return str(super().__call__(source)) + def markdown2html_mistune(source: str) -> str: """Convert a markdown string to HTML using mistune""" return MarkdownWithMath(renderer=IPythonRenderer(escape=False)).render(source) @@ -500,27 +501,22 @@ def heading(self, text, level): self.headings.append((level, text)) return "" # We return an empty string to avoid outputting the headings + def extract_titles_from_markdown_input(markdown_input): # Markdown_input is a single string with all the markdown content concatenated - # Initiate list of titles titles_array = [] - - # Instantiate the custom renderer renderer = HeadingExtractor() - - # Create a Markdown parser with the custom renderer extract_titles = mistune.create_markdown(renderer=renderer) - - # Parse the Markdown extract_titles(markdown_input) + headings = list(zip(*renderer.headings))[1] - # Extracted headings - for level, title in renderer.headings: # renderer.headings is an array for each markdown element + for title in headings: + print('title:', title) children = title["children"] attrs = title["attrs"] raw_text = children[0]["raw"] - level = attrs["level"] + header_level = attrs["level"] id = raw_text.replace(' ', '-') - href= "#" + id - titles_array.append([level, raw_text, id, href]) + href = "#" + id + titles_array.append([header_level, raw_text, id, href]) return titles_array diff --git a/nbconvert/nbconvertapp.py b/nbconvert/nbconvertapp.py index a16327345..d80339123 100755 --- a/nbconvert/nbconvertapp.py +++ b/nbconvert/nbconvertapp.py @@ -223,7 +223,7 @@ def _classes_default(self): return classes - description = Unicode(# type:ignore[assignment] + description = Unicode( # type:ignore[assignment] """This application is used to convert notebook files (*.ipynb) to various other formats. @@ -342,7 +342,7 @@ def _postprocessor_class_changed(self, change): if new: self.postprocessor_factory = import_item(new) - export_format = Unicode(# type:ignore[call-overload] + export_format = Unicode( # type:ignore[call-overload] allow_none=False, help=f"""The export format to be used, either one of the built-in formats {get_export_names()} diff --git a/tests/base.py b/tests/base.py index ff2bec3d5..d854900a8 100644 --- a/tests/base.py +++ b/tests/base.py @@ -176,15 +176,15 @@ def assert_big_text_equal(a, b, chunk_size=80): to give better info than vanilla assertEqual for large text blobs. """ for i in range(0, len(a), chunk_size): - chunk_a = a[i : i + chunk_size] - chunk_b = b[i : i + chunk_size] + chunk_a = a[i: i + chunk_size] + chunk_b = b[i: i + chunk_size] assert chunk_a == chunk_b, "[offset: %i]\n%r != \n%r" % (i, chunk_a, chunk_b) if len(a) > len(b): raise AssertionError( - "Length doesn't match (%i > %i). Extra text:\n%r" % (len(a), len(b), a[len(b) :]) + "Length doesn't match (%i > %i). Extra text:\n%r" % (len(a), len(b), a[len(b):]) ) if len(a) < len(b): raise AssertionError( - "Length doesn't match (%i < %i). Extra text:\n%r" % (len(a), len(b), a[len(b) :]) + "Length doesn't match (%i < %i). Extra text:\n%r" % (len(a), len(b), a[len(b):]) )