在web应用中常用JSON(JavaScript Object Notation)格式传输数据,例如利用Baidu语音识别服务做语音识别,将本地音频数据post到Baidu语音识别服务器,服务器响应结果为json字符串:
{"corpus_no":"6303355448008565863","err_msg":"success.","err_no":"0","result":["你好,"],"sn":"418359718861467614305""}
py读写json:
# 使用标准库中的json模块,其中loads,dumps函数可以完成json数据的读写
# coding:utf-8
import requests
import json
# 录音
from record import Record
record = Record(channels=1) # 单声道录音实例
audioData = record.record(2) # 2秒音频文件
# 获取token
from secret import API_KEY,SECRET_KEY
authUrl = "https://openapi.baidu.com/oauth/2.0/token?grant_type=client_credentials&client_id=" + API_KEY + "&client_secret=" + SECRET_KEY;
response = requests.get(authUrl)
res = josn.loads(response.content)
token = res['access_token']
# 语音识别
cuid = 'xxxxxxxx'
srvUrl = 'http://vop.baidu.com/server_api' + '?cuid=' + cuid + '&token=' + token
httpHeader = {
'Content-Type':'audio/wav; rate = 0000',
}
response = requests.post(srvUrl,headers=httpHeader,data=audioData)
res = json.loads(response.content)
text = res['result'][0]
print u'\n识别结果:'
print text
#
import json
json.
json.dumps # 把python对象转换成字符串
l = [1,2,3,'abc',{'name':'Bob','age':'13'}]
json.dumps(l) # '[1, 2, 3, "abc", {"name": "Bob", "age": "13"}]'
d = {'b':None,'a':5,'c':'abc'}
json.dumps(d) # '{"a": 5, "c": "abc", "b": null}'
调整输出形式
json.dumps(l,separators=[', ',': '] # 默认分隔符
json.dumps(l,separators=[',',':' ]# '[1,2,3,"abc",{"name":"Bob","age":"13"}]'
排序
json.dumps(d,sort_keys=True) # 默认False。'{"a": 5, "b": null, "c": "abc"}'
把json字符串转成python对象
l2 = json.loads('[1, 2, 3, "abc", {"name": "Bob", "age": "13"}]') # [1,2,3,u'abc',{u'name':u'Bob',u'age':'13'}]
ls[0] # 0
l3 = json.loads('{"a": 5, "c": "abc", "b": null}') # {u'b':None,u'a':5,u'c':u'abc'}
l3['a'] # 5
json.load和json.dump功能一样,接口是文件
with open('demo.json','wb') as f:
json.dump(l,f)
cat demo.json
5.2【数据编码与处理】读写json数据
最新推荐文章于 2024-10-02 10:53:34 发布