Skip to main content

Convert serialized EPUB books into M4B audiobooks with Chatterbox Multilingual TTS.

Project description

chatterbook

Convert EPUB books into M4B audiobooks with Chatterbox Multilingual TTS.

from chatterbook import Book

book = Book("book.epub")
book.convert(
    language="ko",
    voice_path="voices/narrator.wav",
    style="warm",
    batch_size=8,
    speed=0.9,
)

Book reads the EPUB immediately and builds a JSON-compatible representation with title, chapters, paragraphs, narration/dialogue segments, and pause timing. You can serialize and restore that representation without reading the EPUB again:

data = book.to_dict()
book = Book.from_dict(data)
book.convert("audiobooks/book.m4b", language="ko")

By default, the output filename is read from the EPUB title metadata and written as Title.m4b in the current directory. You can also pass a path or directory.

voice_path is an optional short WAV reference clip for voice cloning. If it is omitted, Chatterbox's bundled default conditionals are used. To use separate voices for narration and dialogue, pass narrator_voice_path and dialogue_voice_path. When combined with voice_path, the shared voice is used as the default and the narrator/dialogue-specific paths override their side.

Chapters are split into paragraph and speech segments when the Book is built. Quoted dialogue is marked separately and generated with slightly more expressive settings. Commas, sentence endings, paragraph breaks, and narration/dialogue transitions add real silence after each segment to improve audiobook pacing.

The default audiobook pacing is intentionally slower than raw TTS:

  • speed=0.9
  • comma_pause_ms=200
  • sentence_pause_ms=300
  • paragraph_pause_ms=600
  • dialogue_pause_ms=300

M4B output requires ffmpeg on your PATH. During conversion, chatterbook shows one colored tqdm progress bar for the whole EPUB. Pass show_progress=False to disable it.

When voice_path is used, conversion prepares voice conditionals once per same-style batch instead of once per segment. Tune batch_size to control how many adjacent narration or dialogue segments are grouped for that preparation step.

book.convert(
    language="ko",
    narrator_voice_path="voices/narrator.wav",
    dialogue_voice_path="voices/dialogue.wav",
)

To export chapter WAV files instead of one M4B:

book.convert(
    "audio",
    language="ko",
    output_format="wav",
)

Styles

  • neutral: balanced default
  • warm: slightly softer narration
  • dramatic: more expressive narration

You can override a style with explicit generation values:

book.convert(
    language="ko",
    exaggeration=0.7,
    cfg_weight=0.3,
)

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

chatterbook-0.5.0.tar.gz (234.4 kB view details)

Uploaded Source

Built Distribution

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

chatterbook-0.5.0-py3-none-any.whl (14.6 kB view details)

Uploaded Python 3

File details

Details for the file chatterbook-0.5.0.tar.gz.

File metadata

  • Download URL: chatterbook-0.5.0.tar.gz
  • Upload date:
  • Size: 234.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for chatterbook-0.5.0.tar.gz
Algorithm Hash digest
SHA256 bce35b69372cdc95e30c3f7208aa59bf8a62f6e21b13eed6b2f547b6e64bfbe9
MD5 1ef651ed953698c898df60b033c1c9b4
BLAKE2b-256 6d56c8818af4d6f402ac882aba5bdaaf35a32f5bd0f4c4542b5b2285a8ddb131

See more details on using hashes here.

Provenance

The following attestation bundles were made for chatterbook-0.5.0.tar.gz:

Publisher: workflow.yml on smturtle2/chatterbook

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file chatterbook-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: chatterbook-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 14.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for chatterbook-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b65d79a57cd61aae5909eed745455b23c5606e0e8c170d5d35b5a1ba59410bc9
MD5 e195a0dced7c7ee56a213dd83fa9d884
BLAKE2b-256 85b3575f7b3a7d99228b78f37d9ecbb9d84efd8d9e7f2128077fea58997a140d

See more details on using hashes here.

Provenance

The following attestation bundles were made for chatterbook-0.5.0-py3-none-any.whl:

Publisher: workflow.yml on smturtle2/chatterbook

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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