Skip to main content

Tool that allows you to export your Notion pages to markdown files.

Project description

notion-exporter: Export Notion pages to Markdown

This python package allows you to easily export your Notion pages to Markdown by providing a Notion API token.

Given that the Notion API is subject to some rate limits, this tool will automatically retry failed requests and wait for the rate limit to reset before retrying. This is especially useful when exporting a large number of pages. Furthermore, this package uses asyncio to make requests in parallel, which can significantly speed up the export process.

Installation

pip install notion-exporter

Usage

from notion_exporter import NotionExporter

exporter = NotionExporter(notion_token="<your-token>")
exported_pages = exporter.export_pages(page_ids=["<list-of-page-ids>"])

# exported_pages will be a dictionary where the keys are the page ids and 
# the values are the page content in markdown format

The NotionExporter class takes the following arguments:

  • notion_token: Your Notion API token. You can find information on how to get an API token in Notion's documentation
  • export_child_pages: Whether to recursively export all child pages of the provided page ids. Defaults to False.
  • extract_page_metadata: Whether to extract metadata from the page and add it as a frontmatter to the markdown. Extracted metadata includes title, author, path, URL, last editor, and last editing time of the page. Defaults to False.
  • exclude_title_containing: If specified, pages with titles containing this string will be excluded. This might be useful for example to exclude pages that are archived. Defaults to None.

The NotionExporter.export_pages method takes the following arguments:

  • page_ids: A list of page ids to export. If export_child_pages is True, all child pages of these pages will be exported as well.
  • database_ids: A list of database ids to export. If export_child_pages is True, all pages in these databases will be exported as well.
  • ids_to_exclude: A list of page ids to exclude when recursively exporting child pages. If an excluded page is encountered, its child pages will not be exported either.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

notion_exporter-0.1.1.tar.gz (14.5 kB view hashes)

Uploaded Source

Built Distribution

notion_exporter-0.1.1-py3-none-any.whl (15.0 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page