Skip to main content

A CLI tool for generating Markdown notes from academic PDF papers using customizable templates, Zotero metadata, and LLM-powered summaries.

Project description

Zotomatic

Zotomatic is a CLI tool that generates Markdown research notes from PDFs using user-defined templates, Zotero metadata, and extracted text.

Zotomatic は、研究論文の PDF から Zotero の書誌情報や本文抽出結果をもとに、 ユーザー定義テンプレートに従った Markdown 形式の研究ノートを自動生成する CLI ツールです。
日本語版READMEはこちら


Quick Start

Start Guide

Install

pip install zotomatic
zotomatic init --pdf-dir ./papers  # Directory for PDFs

Generate notes from a PDF file

Generate a Markdown note from a specific PDF in any directory.
pdf_dir is not required.

zotomatic scan --path ./papers/sample.pdf

Batch process PDFs under the configured directory

Process all PDFs under the configured directory.
pdf_dir is required.

zotomatic scan --once

Watch the configured directory for new PDFs

Watch the configured directory and generate notes whenever a PDF is added.
pdf_dir is required.

zotomatic scan --watch

Overview

Zotomatic is a CLI tool that starts from research PDFs, uses bibliographic information and extracted text, and generates Markdown notes based on user-defined templates.

For PDFs managed in Zotero, Zotomatic can fetch metadata such as authors, title, and abstract to produce notes enriched with bibliographic details. It can also generate minimal notes for PDFs outside Zotero.

Zotomatic can optionally integrate with an LLM to generate summaries and tags in a specified language and insert the results into notes.
Note: Output quality and accuracy depend on the LLM.

Notes are plain Markdown files, and templates are fully user-defined. You can use them with any editor or knowledge tool, including Obsidian.


Key Features

  • Automatic Markdown note generation from research PDFs
    Avoid manual note taking and output reusable research notes in Markdown.

  • Automatic metadata retrieval from Zotero-managed PDFs
    Pull authors, title, abstract, and other bibliographic data from Zotero and insert them into notes.

  • Support for PDFs outside Zotero
    Generate minimal, structured notes even when PDFs are not registered in Zotero.

  • Best-effort completion for missing metadata
    If Zotero metadata is incomplete, Zotomatic attempts to fill missing fields from PDF text.
    Note: Completion runs only for Zotero-managed PDFs.

  • Flexible, user-defined templates
    Customize headings and sections to match your workflow.

  • Optional LLM summaries and tags (language-selectable)
    Generate summaries and tags via LLM when enabled (OpenAI API only for now).

  • Multiple scan modes
    Use watch, once, or path mode to fit your workflow.


Installation

pip install zotomatic

Use Cases

  • Auto-generate notes from PDFs saved in the browser
    Save a PDF via Zotero Connector and run scan --watch for real-time note creation.
  • Batch-generate notes for an existing library
    Run scan --once to process everything under pdf_dir.
  • Spot-process PDFs outside Zotero
    Use scan --path for quick, file-specific note generation.
  • Auto-insert summaries and tags (optional)
    With an API key, generate summaries and tags in a chosen language (OpenAI API only for now).

If you want Zotero metadata, keep the Zotero desktop app running.

See docs/en/getting-started.md for step-by-step instructions.


Documentation


Roadmap

  • Support LLM providers beyond OpenAI (e.g., Gemini)

Note: Roadmap items and timelines may change.


Notes

  • Zotomatic is a research support tool and does not guarantee the accuracy of generated summaries or tags.
  • Always verify results against the original paper before citing.

License

MIT License


Support and Feedback

Please use GitHub Issues for bug reports.

This is a personal project, so not all issues or pull requests can be addressed. Pull requests are not accepted at this time.

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

zotomatic-0.1.1.tar.gz (129.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

zotomatic-0.1.1-py3-none-any.whl (70.4 kB view details)

Uploaded Python 3

File details

Details for the file zotomatic-0.1.1.tar.gz.

File metadata

  • Download URL: zotomatic-0.1.1.tar.gz
  • Upload date:
  • Size: 129.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.1

File hashes

Hashes for zotomatic-0.1.1.tar.gz
Algorithm Hash digest
SHA256 7cc1c45f2b6f8b5ef1d5cd4ed0576b3586e5a8d62274a388b0f175f71502a227
MD5 a0c779e9d61cbfa200ae3f6341459ff6
BLAKE2b-256 e28dde35fc7c64bb1a6bd1b4a08df691ae358fcc0960b8d70993a5a8b92e00d1

See more details on using hashes here.

File details

Details for the file zotomatic-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: zotomatic-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 70.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.1

File hashes

Hashes for zotomatic-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1e4cb9b7b099e476d0c0e747a670d1d03b65c34d7c83c2047d99e75ac73ffe58
MD5 0d18c1fb1c956d2e2c38c49217f093cb
BLAKE2b-256 5ead6b7893137a97cff52d8e3db5626a5fdd9762b705de379d267254bdd7ff99

See more details on using hashes here.

Supported by

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