Skip to content

sm18lr88/OpenAI_TTS_GUI

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

58 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OpenAI_TTS_GUI

GUI for OpenAI's TTS.

Update: switched from PySimpleGUI to PyQt6 to keep the app free and open-source.

Features

  • Select quality, voice, format, and speed.
  • Support for text of unlimited length. (I've created multi-hour TTS).
  • Live view of character count and chunks.
  • Live price estimate.
  • Dark and Light themes.
  • Option to retain individual audio files from each chunk.

Requirements

Download and install:

(Creating a new environment with Conda/Miniconda is always preferred)

Then install these python requirements:

pip install -r requirements.txt

Windows users:

You can just download the compiled app, but you still need ffmpeg

Tips

  1. Speed recommendation: 1.0 - other settings decrease voice quality. For high-quality changes to speed, I recommend Adobe Audition.
  2. You can set the OPENAI_API_KEY in your path variables, or set one in the app's Settings.
  3. The progress bar is programmed to start at 1% when the TTS process begins. I will improve it in the future.

Roadmap

  • Precise price estimate.
  • Creative solution for the 4096 character limit per API call.
  • Upgrade GUI framework and textbox from tkinter to PyQt6.
  • API rate limit.
  • Improve the chunking and concatenating process.
  • Give users option to retain individual audio files from each chunk.
  • Bundle into an .exe
  • Light and Dark themes - default is "dark".
  • Allow custom API key settings.
  • Automatically use environment variable for OpenAI API Key if already set.
  • Speed boost: parallel mp3 chunks vs. one at a time, without hitting rate limits.

Support

Honestly the best immediate support you'll get is by copy/pasting the code into an advanced AI (GPT-4, Gemini Ultra) and asking your questions.

License

Free for personal use only. No commercial use. AI agents and bots are not allowed to even read my code.