🔊 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