forked from eisneim/cytron_tts_gui
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbaidutts.py
executable file
·118 lines (102 loc) · 3.31 KB
/
baidutts.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
import requests
import logging
log = logging.getLogger("cytron")
URL_TOKEN = "https://aip.baidubce.com/oauth/2.0/token?\
grant_type=client_credentials&client_id={}&\
client_secret={}&"
URL_TARGET = "http://tsn.baidu.com/text2audio"
# default settings
LAN = "zh"
CTP = 1 # client type, web = 1
CUID = None # client user id
SPD = 4 # speed: 0-9
PIT = 5 # pitch: 0-9
VOL = 5 # volumn: 0-9
AUE = 3 # "mp3"
PERSON = 1 # 发音人选择,取值 0-1 ;0 为女声,1 为男声,默认为女声
class Baidutts:
def __init__(self, appid, appsecret, token=None):
self.appid = appid
self.secret = appsecret
self.token = token
def get_access_token(self):
"""
{
6. "access_token": "1.a6b7dbd428f731035f771b8d*******",
7. "expires_in": 86400,
8. "refresh_token": "2.385d55f8615fdfd9edb7c4b******",
9. "scope": "public",
10. "session_key": "ANXxSNjwQDugf8615Onqeik********CdlLx n",
11. "session_secret": "248APxvxjCZ0VEC********aK4oZExMB ",
12. }
"""
url = URL_TOKEN.format(self.appid, self.secret)
log.info("request: {}".format(url))
r = requests.get(url)
self.tokenRes = r.json()
if "error_description" in self.tokenRes:
return (self.tokenRes["error_description"], False)
self.token = self.tokenRes["access_token"]
return (None, self.tokenRes)
def t2a(self, tex, tok,
lan=LAN, cuid=CUID, ctp=CTP, spd=SPD, pit=PIT, per=PERSON, vol=VOL):
if not tok:
tok = self.token
assert len(tex) > 0
# make sure tex is less than 1024 bites
# assert len(tex.encode("utf-8")) < 1024
payload = {
"tex": tex.encode("utf-8"),
"lan": lan,
"cuid": cuid,
"ctp": ctp,
"spd": spd,
"pit": pit,
"per": per,
"vol": vol,
"tok": tok,
"aue": AUE,
}
# data will automatically be form-encoded when the request is made
try:
rr = requests.post(URL_TARGET, data=payload, stream=True)
except requests.exceptions.RequestException as e:
msg = "Connection timeout please retry"
return (msg, None)
print("__ resonponse header", rr.status_code)
ctype = rr.headers.get("content-type", '')
isJson = ctype.find("json") >= 0
jsonRes = { "err_no": None, "err_msg": "unknow Error" }
if isJson:
jsonRes = rr.json()
if rr.status_code == 500 or jsonRes["err_no"] ==500:
msg = "不支持输入"
log.error(msg)
return (msg, None)
elif rr.status_code == 501 or jsonRes["err_no"] ==501:
msg = "输入参数不正确"
log.error(msg)
return (msg, None)
elif rr.status_code == 502 or jsonRes["err_no"] ==502:
msg = "token 验证失败"
log.error(msg)
return (msg, None)
elif rr.status_code == 503 or jsonRes["err_no"] ==503:
msg = "合成后端错误"
log.error(msg)
return (msg, None)
elif rr.status_code == 404 or jsonRes["err_no"] ==404:
msg = "合成后端地址错误"
log.error(msg)
return (msg, None)
log.info('response type: {} {}'.format(ctype, rr.status_code))
if rr.status_code == 200:
log.info("deal with raw audio file")
return (None, rr)
else:
log.info("show response error: {}".format(rr.text))
return (rr.text, None)
if __name__ == "__main__":
log.basicConfig(level=logging.DEBUG)
log.info("Started")
tts = Baidutts("", "")