本人python小白一枚,在学习百度翻译api方面的内容。以下是借用‘我有一碗酒可以慰风尘’的一篇文章中的代码改写的。
import random
import hashlib
import urllib.parse
import json
import http.client
def baidu_translation(content):
appid = '*****' # 你的appid
secretKey = '*****' # 你的密钥
myurl = '/api/trans/vip/translate'
httpClient = None
q = content
fromLang = 'en'
toLang = 'zh'
salt = random.randint(32768, 65536)
sign = appid + q + str(salt) + secretKey
sign = hashlib.md5(sign.encode()).hexdigest()
myurl = myurl + '?appid=' + appid + '&q=' + urllib.parse.quote(q) + '&from=' + fromLang + '&to=' + toLang + '&salt=' + str(salt) + '&sign=' + sign
try:
httpClient = http.client.HTTPConnection('api.fanyi.baidu.com')
httpClient.request('GET', myurl)
# response是HTTPResponse对象
response = httpClient.getresponse()
jsonResponse = response.read().decode("utf-8") # 获得返回的结果,结果为json格式
js = json.loads(jsonResponse) # 将json格式的结果转换字典结构
dst = str(js["trans_result"][0]["dst"]) # 取得翻译后的文本结果
return dst # 返回翻译结果
except Exception as e:
return e
finally:
if httpClient:
httpClient.close()
print(baidu_translation('open'))
print('第一次调用翻译函数翻译成功')
print('='*30)
print(baidu_translation('close'))
print('第2次调用翻译函数翻译失败')
下边是打印结果
打开
第一次调用翻译函数翻译成功
==============================
'trans_result'
第2次调用翻译函数翻译失败
哪位高手,给找一下问题在哪里?为什么不能重复调用翻译函数?
下边是用遍历的方法调用翻译函数
content = ['name', 'close', 'open']
for i in content:
print(baidu_translation(i))
结果也是这样
名称
'trans_result'
'trans_result'
自己解决了。
time.sleep(1)
加个等待时间就可以了,估计是百度检测到,访问速度太快了。
你好,我是有问必答小助手,非常抱歉,本次您提出的有问必答问题,技术专家团超时未为您做出解答
本次提问扣除的有问必答次数,将会以问答VIP体验卡(1次有问必答机会、商城购买实体图书享受95折优惠)的形式为您补发到账户。
因为有问必答VIP体验卡有效期仅有1天,您在需要使用的时候【私信】联系我,我会为您补发。