npm install say
const say = require('say')
// Use default system voice and speed
say.speak('Hello!')
// Stop the text currently being spoken
say.stop()
// More complex example (with an OS X voice) and slow speed
say.speak("What's up, dog?", 'Alex', 0.5)
// Fire a callback once the text has completed being spoken
say.speak("What's up, dog?", 'Good News', 1.0, (err) => {
if (err) {
return console.error(err)
}
console.log('Text has been spoken.')
});
// Export spoken audio to a WAV file
say.export("I'm sorry, Dave.", 'Cellos', 0.75, 'hal.wav', (err) => {
if (err) {
return console.error(err)
}
console.log('Text has been saved to hal.wav.')
})
say.setPlatform(say.platforms.WIN32 || say.platforms.MACOS || say.platforms.LINUX)
- Speed: 1 = 100%, 0.5 = 50%, 2 = 200%, etc
say.speak(text, voice || null, speed || null, callback || null)
- MacOS & Windows Only (Windows ignores endian and data type parts of the dataFormat, can only output sample size to 8 or 16 bit)
- Speed: 1 = 100%, 0.5 = 50%, 2 = 200%, etc
- dataFormat: As per macOS say e.g. "BEF16@22100" is big endian, floating point, 16bit, 22100kHz, defaults to "LEF32@32000" if unspecified
say.export(text, voice || null, speed || null, filename, callback || null, dataFormat || null)
say.stop(callback || null)
say.getInstalledVoices(callback)
Unfortunately every feature isn't supported on every platform. PR's welcome!
Platform | Speak | Export | Stop | Speed | Voice |
---|---|---|---|---|---|
macOS | ✅ | ✅ | ✅ | ✅ | ✅ |
Linux | ✅ | 🚫 | ✅ | ✅ | ✅ |
Windows | ✅ | ✅ | ✅ | ✅ | ✅ |
Voices in macOS are associated with different localities. To a list of voices and their localities run the following command:
say -v "?"
As an example, the default voice is Alex
and the voice used by Siri is Samantha
.
Linux support requires Festival, which uses less friendly names for its voices. Voices for Festival sometimes need to be installed separately. You can check which voices are available by running festival
, typing (voice_
, and pressing Tab. Then take the name of the voice you'd like to try, minus the parentheses, and pass it in to say.js.
The .export()
method is not available.
Try the following commad to install Festival with a default voice:
sudo apt-get install festival festvox-kallpc16k
- Mac OS X (comes with
say
) - Linux with Festival installed
- Windows (comes with SAPI.SpVoice)