53 lines
		
	
	
		
			No EOL
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			No EOL
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #!/usr/bin/env python
 | |
| import sys
 | |
| if sys.version_info[0] >= 3:
 | |
|     import PySimpleGUI as sg
 | |
| else:
 | |
|     import PySimpleGUI27 as sg
 | |
| from gtts import gTTS
 | |
| from pygame import mixer
 | |
| import time
 | |
| import os
 | |
| 
 | |
| '''
 | |
|     Simple demonstration of using Google Text to Speech
 | |
|     Get a multi-line string
 | |
|     Convert to speech
 | |
|     Play back the speech
 | |
|     
 | |
|     Note that there are 2 temp files created. The program tries to delete them but will fail on one of them
 | |
| '''
 | |
| 
 | |
| layout = [[sg.Text('What would you like me to say?')],
 | |
|           [sg.Multiline(size=(60,10), enter_submits=True)],
 | |
|           [sg.Button('Speak', bind_return_key=True), sg.Exit()]]
 | |
| 
 | |
| window = sg.Window('Google Text to Speech').Layout(layout)
 | |
| 
 | |
| i = 0
 | |
| mixer.init()
 | |
| while True:
 | |
|     event, values = window.Read()
 | |
|     if event is None or event == 'Exit':
 | |
|         break
 | |
|     # Get the text and convert to mp3 file
 | |
|     tts = gTTS(text=values[0], lang='en',slow=False)
 | |
|     tts.save('speech{}.mp3'.format(i%2))
 | |
|     # playback the speech
 | |
|     mixer.music.load('speech{}.mp3'.format(i%2))
 | |
|     mixer.music.play()
 | |
|     # wait for playback to end
 | |
|     while mixer.music.get_busy():
 | |
|         time.sleep(.1)
 | |
|     mixer.stop()
 | |
|     i += 1
 | |
| 
 | |
| # try to remove the temp files. You'll likely be left with 1 to clean up
 | |
| try:
 | |
|     os.remove('speech0.mp3')
 | |
| except:
 | |
|     pass
 | |
| try:
 | |
|     os.remove('speech1.mp3')
 | |
| except:
 | |
|     pass |