๐ A powerful and easy-to-use Python Text-to-Speech library that supports multiple TTS engines.
- ๐๏ธ Multiple TTS engine support:
- ๐ฅ๏ธ pyttsx3 (offline, default) - Works without internet
- ๐ Google TTS - High-quality online TTS
- ๐๏ธ Voice customization:
- ๐โโ๏ธ Adjustable speech rate
- ๐ Volume control
- ๐ฅ Multiple voice options
- ๐พ Save audio to multiple formats (MP3, WAV)
- ๐ Smart file management with auto-cleanup
- ๐ฅ๏ธ Cross-platform compatibility (Windows, Linux, macOS)
- ๐ก๏ธ Robust error handling
- ๐ Well-documented API
pip install pyttslibfrom pyttslib import TextToSpeech
# Create a TTS instance (default: pyttsx3 engine)
tts = TextToSpeech()
# Basic text-to-speech
tts.speak("Hello, world!")
# Use Google TTS instead
gtts = TextToSpeech(engine="google")
gtts.speak("Hello from Google Text-to-Speech!")
# Save speech to a file
tts.save_to_file("This will be saved as audio.", "output.mp3")# Configure pyttsx3 engine
tts = TextToSpeech(engine="pyttsx3", engine_config={
"rate": 150, # Words per minute
"volume": 0.8, # Volume level (0.0 to 1.0)
})
# Configure Google TTS
tts = TextToSpeech(engine="google", engine_config={
"lang": "en", # Language code
"tld": "com", # Top-level domain
"slow": False # Normal speed
})# List available voices
voices = tts.list_voices()
for voice in voices:
print(f"Voice: {voice['name']} (ID: {voice['id']})")
# Set a specific voice
tts.set_voice("en_female_1") # Voice ID from list_voices()# Adjust speech rate (pyttsx3 only)
tts.set_rate(150) # Words per minute
# Adjust volume (pyttsx3 only)
tts.set_volume(0.8) # 80% volumeThe package includes example scripts in the examples/ directory:
- ๐
basic_usage.py: Demonstrates fundamental features - ๐ง
advanced_usage.py: Shows advanced functionality
Run the examples:
python examples/basic_usage.py
python examples/advanced_usage.py- ๐ต MP3 (Google TTS)
- ๐ WAV (pyttsx3)
- ๐ผ OGG (platform-dependent)
- ๐น AIFF (platform-dependent)
- ๐ Temporary files are stored in a dedicated folder
- ๐งน Automatic cleanup after playback
- ๐ซ Robust retry mechanism for file operations
- ๐ Safe file handling with proper resource cleanup
โ ๏ธ Custom exception classes for better error management- ๐ Automatic retries for transient failures
- ๐ข Clear error messages and logging
- ๐ก๏ธ Graceful fallbacks for playback methods
Contributions are welcome! Here's how you can help:
- ๐ด Fork the repository
- ๐ฟ Create your feature branch (
git checkout -b feature/amazing-feature) - ๐พ Commit your changes (
git commit -m 'Add amazing feature') - ๐ค Push to the branch (
git push origin feature/amazing-feature) - ๐ฏ Open a Pull Request
MIT License - feel free to use this in your projects!
- ๐ค pyttsx3 for offline TTS
- ๐ gTTS for Google TTS support
- ๐ playsound for cross-platform audio playback
- ๐ง Report issues on GitHub
- ๐ญ Submit feature requests
- ๐ค Pull requests are welcome
Made with โค๏ธ for the Python community