epub2tts-edge is a free and open source python app to easily create a full-featured audiobook from an epub or text file using realistic text-to-speech from Microsoft Edge TTS.
- Creates standard format M4B audiobook file
- Automatic chapter break detection
- Embeds cover art if specified
- Uses MS Edge for free cloud-based TTS
- Reads sentences in parallel for very fast audiobook creation
- Resumes where it left off if interrupted
- NOTE: epub file must be DRM-free
Usage instructions
NOTE: If you want to specify where NLTK tokenizer will be stored (about 50mb), use an environment variable: export NLTK_DATA="your/path/to/nltk_data"
source .venv/bin/activate
epub2tts-edge mybook.epub
- edit mybook.txt, replacing
# Part 1
etc with desired chapter names, and removing front matter like table of contents and anything else you do not want read. Note: First two lines can be Title: and Author: to use that in audiobook metadata.
epub2tts-edge mybook.txt --cover mybook.png
- Optional: specify a speaker with
--speaker <speaker>
. List available voices withedge-tts --list-voices
, default speaker isen-US-AndrewNeural
if--speaker
is not specified.
-h, --help
- show this help message and exit--speaker SPEAKER
- Speaker to use (example: en-US-EricNeural)--cover image.[jpg|png]
- image to use for cover--paragraphpause <N>
- number of milliseconds to pause between paragraphs--sentencepause <N>
- number of milliseconds to pause between sentences
deactivate
How to report bugs/issues
Thank you in advance for reporting any bugs/issues you encounter! If you are having issues, first please search existing issues to see if anyone else has run into something similar previously.
If you've found something new, please open an issue and be sure to include:
- The full command you executed
- The platform (Linux, Windows, OSX, Docker)
- Your Python version if not using Docker
Release notes
- 20240628: Improved how chapter items are ordered (https://github.com/prydom)
- 20240627: Added check for NLTK tokenizer, download if not already there
- 20240626: Catch multiple !!! and ??? which chokes Edge TTS (https://github.com/erfansamandarian)
- 20240609: Added progress bar (https://github.com/The-Ducktor)
- 20240502: Added export of cover image
- 20240429: Fixed issues with running on linux
- 20240428: Improved final audio by using flac for intermediate audio files, sounds much better
- 20240412: Initial release
Required Python version is 3.11.
NOTE: If you want to specify where NLTK tokenizer will be stored (about 50mb), use an environment variable: export NLTK_DATA="your/path/to/nltk_data"
MAC INSTALLATION
This installation requires Python < 3.12 and Homebrew (I use homebrew to install espeak, pyenv and ffmpeg).
#install dependencies
brew install espeak pyenv ffmpeg
#install epub2tts-edge
git clone https://github.com/aedocw/epub2tts-edge
cd epub2tts-edge
pyenv install 3.11
pyenv local 3.11
#OPTIONAL - install this in a virtual environment
python -m venv .venv && source .venv/bin/activate
pip install .
LINUX INSTALLATION
These instructions are for Ubuntu 24.04.1 LTS and 22.04 (20.04 showed some depedency issues), but should work (with appropriate package installer mods) for just about any distro. Ensure you have ffmpeg
installed before use.
#install dependencies
sudo apt install espeak-ng ffmpeg python3-venv
#clone the repo
git clone https://github.com/aedocw/epub2tts-edge
cd epub2tts-edge
#OPTIONAL - install this in a virtual environment
python3 -m venv .venv && source .venv/bin/activate
pip install .
WINDOWS INSTALLATION
Running epub2tts in WSL2 with Ubuntu 22 is the easiest approach, but these steps should work for running directly in windows.
This guide will assume that you know how to use:
- Windows PowerShell, some basics like running commands and changing directories
- GIT clone or at least capability to download repository from github site
This installation requires: python3.11, espeak-ng, ffmpeg. To whitch appropriate windows versions are provided throughout the installation process below:
STEP 1: Get and set up all requirements:
Install python 3.11.
Install latest espeak-ng release (.msi x64 for 64 bit windows).
Download ffmpeg package, github release has binaries for windows.
Unpack ffmpeg and add the bin folder to environmental variables according to this tutorial.
STEP 2: Copy repository and install the app and its dependencies using PowerShell:
Install virtual environment python library:
pip install virtualenv
Clone the repo to your desired directory, i'll use 'C:\epub2tts-edge' as an example:
git clone https://github.com/aedocw/epub2tts-edge
Set powershell directory to your cloned repo:
cd C:\epub2tts-edge
Create virtual environment inside the directory:
py -m venv .venv
Run the app in virtual environment:
.venv\scripts\activate
Install the app and its required libs inside:
pip install .
STEP 3: Test the app and make sure everything works as intended.
This is done by geting a short sample ebook and converting it to an audiobook using the app.
Download this sample ebook, or anything from epub-samples on github (or something short with a cover).
Now run this command on your .epub to convert it to a separate text and cover image:
epub2tts-edge sample.epub
You should now have both sample.txt and sample.png in the repo folder, you can check them out and edit them before making an audiobook.
Lastly, run the conversion and make a sample TTS audiobook:
epub2tts-edge sample.txt --cover sample.png
Installation done, you should now get a sample.m4u file. If it works then it's all good and you can get into converting your books.
DOCKER
Build the image
docker build . -t epub2tts_edge
Generate the txt file and modify as necessary.
docker run --rm -it -v ~/Downloads:/files epub2tts_edge "/files/<epub_file>.epub"
Generate audiobook.
docker run --rm -it -v ~/Downloads:/files epub2tts_edge "/files/<epub_file>.txt" [options]
The volume argument ~/Downloads:/files
maps ~/Downloads
on the host, to the path /files
inside the container, so our paths added as cli arguments should also include the /files
base path.
UPDATING YOUR INSTALLATION
- cd to repo directory
git pull
- Activate virtual environment you installed epub2tts in if you installed in a virtual environment using "source .venv/bin/activate"
pip install . --upgrade
👤 Christopher Aedo
👥 Contributors
Contributions, issues and feature requests are welcome!
Feel free to check the issues page or discussions page.
Give a ⭐️ if this project helped you!