Skip to main content

A tool to standardize audiobook files into single m4b files with clean metadata based on Audible and chapters.

Project description

Functionality

The steps accomplished by using this tool are as follows:

  • Easy batch inputs via -i folder1/ folder2/* file.mp3 etc.
  • Only user input required is one ASIN per book.
  • Converts mp3(s) into single m4b files
    • Matches existing bitrate and samplerate for target file.
    • Standardizes chapter names, like 'Chapter 1'.
  • Merges or edits m4a/m4b into single m4b file, without re-converting.
  • Moves input file/folder to done folder when processed.

Audible data features:

  • Title, author(s), narrator(s), series, release year, description
    • For generating folder structure
    • For seeding M4b metadata fields
  • Chapters (title and length) used for m4b/m4a inputs.

CLI usage

usage: m4b-merge [-h] -i INPUTS [INPUTS ...] [--log_level LOG_LEVEL]

m4b-merge cli

optional arguments:
  -h, --help            show this help message and exit
  -i INPUTS [INPUTS ...], --inputs INPUTS [INPUTS ...]
                        Input paths to process
  --log_level LOG_LEVEL
                        Set logging level
  • Check the user editable variables in config.py, and see if there's anything you need to change.
  • On first run, you will be prompted to signin to Audible. This is a one-time process that will be saved to your system's relevant config folder, under m4b-merge.

Module usage

If you are a developer wanting to use this in a project, you can import the modules as so: from m4b_merge import audible_helper, config, helpers, m4b_helper

And then creating the objects you need (from audible_helper.BookData(asin) and m4b_helper.M4bMerge(input_data, metadata)) You can see more usage examples in the sister project, Bragi Books

The parser function in audible_helper.BookData returns some extra data not used in the CLI here. This is a list of all data returned:

  • Title
  • Short Summary
  • Long Summary
  • Authors
  • Narrators
  • Series
  • Release Date
  • Publisher
  • Language
  • Runtime in minutes
  • Format type (abridged, unabridged, other)

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

m4b-merge-0.3.5.tar.gz (23.8 kB view details)

Uploaded Source

Built Distribution

m4b_merge-0.3.5-py3-none-any.whl (24.3 kB view details)

Uploaded Python 3

File details

Details for the file m4b-merge-0.3.5.tar.gz.

File metadata

  • Download URL: m4b-merge-0.3.5.tar.gz
  • Upload date:
  • Size: 23.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.6

File hashes

Hashes for m4b-merge-0.3.5.tar.gz
Algorithm Hash digest
SHA256 b9101ac477206160c812a049e87e1c1b33ec4460580398a9c417448a447fef7e
MD5 811d84f71efa68d93b6be6068d076d46
BLAKE2b-256 97950b0e5c7a003e5e083bdb655536a0ae133157ceba9d1612ebfd6501486b78

See more details on using hashes here.

File details

Details for the file m4b_merge-0.3.5-py3-none-any.whl.

File metadata

  • Download URL: m4b_merge-0.3.5-py3-none-any.whl
  • Upload date:
  • Size: 24.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.6

File hashes

Hashes for m4b_merge-0.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 65a89bc18baf67c4fad595daa631c47ea0c93a8a188509a00ecedd4d18af9e2b
MD5 4464398d3fff16e54d863413eeddfbf8
BLAKE2b-256 ce5faeb392fa1af8429d11429f7adba9ce803ae983125a89989cc4e6c1e26242

See more details on using hashes here.

Supported by

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