写一段python代码实现中文语音识别
时间: 2023-11-17 16:49:57 浏览: 199
要实现中文语音识别,我们可以使用百度AI平台的语音识别API。以下是使用Python编写的示例代码:
```python
import requests
import json
# 百度AI平台的API Key和Secret Key
API_KEY = 'your_api_key'
SECRET_KEY = 'your_secret_key'
# 需要识别的音频文件路径
AUDIO_FILE = 'path/to/audio/file'
# 构造请求头
headers = {
'Content-Type': 'audio/wav;rate=16000',
'Content-Length': str(os.path.getsize(AUDIO_FILE)),
}
# 构造请求参数
params = {
'format': 'wav',
'dev_pid': 1536, # 中文普通话
'token': '',
'cuid': 'baidu_speech_demo',
'len': os.path.getsize(AUDIO_FILE),
'speech': base64.b64encode(open(AUDIO_FILE, 'rb').read()).decode('utf-8'),
}
# 获取Access Token
def get_access_token(api_key, secret_key):
url = f'https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id={api_key}&client_secret={secret_key}'
response = requests.post(url)
access_token = json.loads(response.text)['access_token']
return access_token
access_token = get_access_token(API_KEY, SECRET_KEY)
params['token'] = access_token
# 发送请求
url = 'https://vop.baidu.com/server_api'
response = requests.post(url, headers=headers, params=params)
# 解析响应结果
if response.status_code == 200:
result = json.loads(response.text)
if 'result' in result:
print(result['result'])
else:
print(result['err_msg'])
else:
print('识别失败')
```
在这个示例中,我们使用了requests库发送HTTP请求,并使用json库解析响应结果。我们需要先获取Access Token,然后才能调用语音识别API。最后,解析响应结果,获取识别到的文字信息。
阅读全文