关于百度翻译api调用的问题

本人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天,您在需要使用的时候【私信】联系我,我会为您补发。