https://github.com/caiyunapp/azuretts
https://github.com/caiyunapp/azuretts
azure-tts tts-api
Last synced: 11 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/caiyunapp/azuretts
- Owner: caiyunapp
- License: apache-2.0
- Created: 2023-12-04T14:24:10.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2025-05-05T19:26:28.000Z (about 1 year ago)
- Last Synced: 2025-07-29T01:47:43.598Z (11 months ago)
- Topics: azure-tts, tts-api
- Language: Go
- Homepage: https://pkg.go.dev/github.com/ringsaturn/azuretts
- Size: 45.9 KB
- Stars: 5
- Watchers: 0
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Azure TTS (Text to Speech) API wrapper for Go.
## Quick Start
```bash
go get github.com/caiyunapp/azuretts
```
```go
package main
import (
"context"
"os"
"github.com/caiyunapp/azuretts"
)
func main() {
c := azuretts.NewClient(
os.Getenv("SPEECH_KEY"),
azuretts.Region(os.Getenv("SPEECH_REGION")),
)
speak := azuretts.NewSpeak(
azuretts.WithLanguage(azuretts.LanguageZhCN),
azuretts.WithVoiceName(azuretts.VoiceNameZhCNYunxiNeural),
azuretts.WithStyle(azuretts.StyleChat),
azuretts.WithRate(1),
azuretts.WithVoiceStyledegree(2),
azuretts.WithSpeechText("你好,世界"),
azuretts.WithVolume(100),
)
b, err := c.GetSynthesize(context.Background(), &azuretts.SynthesisRequest{
Speak: speak,
Output: azuretts.AudioOutputFormat_Streaming_Audio16Khz32KbitrateMonoMp3,
})
if err != nil {
panic(err)
}
if err := b.Error(); err != nil {
panic(err)
}
err = os.WriteFile("sample.mp3", b.Body, 0644)
if err != nil {
panic(err)
}
}
```
## CLI
```bash
go install github.com/caiyunapp/azuretts/cmd/azuretts
```
NOTE: Please setup environment variables `SPEECH_KEY` and `SPEECH_REGION` before
running the CLI.
```console
azuretts --help
Usage of ./azuretts:
-language string
Language Flags (default "zh-CN")
-output string
Output File Name (default "audio.mp3")
-rate int
Rate (default 1)
-style string
Style Flags (default "chat")
-styledegree int
Style Degree (default 2)
-text string
Text (default "你好,世界")
-voice string
Voice Flags (default "zh-CN-YunxiNeural")
-volume int
Volume (default 100)
```
## Thanks
I learned a lot from .