谷歌的翻译API老是发生变化,我们需要自己动手来找到谷歌的翻译API,这样才是最稳妥的解决方法
首先,用谷歌浏览器打开谷歌的翻译界面,看一下它是怎么请求数据的
data:image/s3,"s3://crabby-images/9e2b2/9e2b21f5f9aed79b8fb75bbccd1f8dcc8b96d910" alt=""
右键检查,进入开发者工具,选择网络(network),如图所示
data:image/s3,"s3://crabby-images/fc9a8/fc9a80a1d8d17aa1ac19c6211ccf74c7eec9fc0e" alt=""
点击clear清除,把之前所有的请求视觉上清空,方便我们后续查找真正的API请求
data:image/s3,"s3://crabby-images/aa9be/aa9be349959473ced428ebc1ed054c85c1768262" alt=""
data:image/s3,"s3://crabby-images/8e920/8e920d6f59cd363ae5fae8c44c0757bb883d3ec1" alt=""
谷歌翻译大约每秒会请求一次,我们很快就可以得到谷歌服务器返回给我们的翻译结果,经过排查,下面的这个batchexecute开头的请求就是我们需要的,
data:image/s3,"s3://crabby-images/1540e/1540e56d0fba509e7468dbfa7025c397b77ce78c" alt=""
我们点开对其进行进一步分析,可以看到这是一个post的请求
data:image/s3,"s3://crabby-images/62ec4/62ec403b024a6a1511ca1e6fa4303d0dc9f18be5" alt=""
从载荷中可以看到发送post请求时使用的参数,是一个表单数据
data:image/s3,"s3://crabby-images/8c0df/8c0df0150b48f2cba8a08e77fdb38fbed83e98c0" alt=""
从预览中可以看到翻译的结果,是一个JSON格式的数据
data:image/s3,"s3://crabby-images/047e5/047e57ada4ffef4172af4a9e36f014e26d67d817" alt=""
2022.12.26
上面的方法是适用的,只不过是现在这个接口没有以前好找了,我们使用谷歌搜索引擎上提供的谷歌翻译来找这个接口
我们先在网页端测试一个翻译,可以看到这个结果反馈回来了
data:image/s3,"s3://crabby-images/94b52/94b5297d4a4e83a1534ff1f4eeb1fefbbcb84c9b" alt=""
这是一个post请求,自己下一个网址发送自己需要翻译的文本,服务器就会给自己反馈回来对应的结果
谷歌翻译API相关信息
发送网址
### https://www.google.com/async/translate?vet=12ahUKEwjp-9mwmZf8AhXT0GEKHQc7Cs8QqDh6BAgFECw..i&ei=6YepY6njDdOhhwOH9qj4DA&yv=3&cs=0
### https://www.google.com/async/translate
data:image/s3,"s3://crabby-images/21642/21642bc22e2c4e85014dd6d0b3b6078af667e49f" alt=""
提交的数据
### async=translate,sl:zh-TW,tl:zh-CN,st:1111,id:1672054875193,qc:true,ac:true,_id:tw-async-translate,_pms:s,_fmt:pc
data:image/s3,"s3://crabby-images/073f1/073f1441f3c1b83f6f09046a4691082386e739a6" alt=""
data:image/s3,"s3://crabby-images/45cbe/45cbe4fc54b2d79f217d7b1619ee48be0e7f4122" alt=""
不过不出意外的失败了
data:image/s3,"s3://crabby-images/5b113/5b113e923b95b3d9f708140ed6e2f4b7a653aad1" alt=""
实验
去掉参数
data:image/s3,"s3://crabby-images/37ffe/37ffe403612611454f224b5dd6be302446c49649" alt=""
去掉Headers
去掉Content-Length之后就无法返回结果了 #设置的headers参数不够
data:image/s3,"s3://crabby-images/622ad/622ad56eeabc3b6f8e625ca66ffc67fa63555c61" alt=""
结论:headers里面的参数应该尽可能多一点,最好把原请求中的所有参数都带过来
写成对应的Python代码
代码
import requests
url = "https://www.google.com.hk/async/translate"
payload = "async=translate,sl:en,tl:zh-CN,st:1111,id:1672056488960,qc:true,ac:true,_id:tw-async-translate,_pms:s,_fmt:pc"
headers = {
'sec-ch-ua': '"Not?A_Brand";v="8", "Chromium";v="108", "Google Chrome";v="108"',
'DNT': '1',
'sec-ch-ua-mobile': '?0',
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36',
'sec-ch-ua-arch': '"x86"',
'sec-ch-ua-full-version': '"108.0.5359.125"',
'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8',
'sec-ch-ua-platform-version': '"10.0.0"',
'sec-ch-ua-full-version-list': '"Not?A_Brand";v="8.0.0.0", "Chromium";v="108.0.5359.125", "Google Chrome";v="108.0.5359.125"',
'sec-ch-ua-bitness': '"64"',
'sec-ch-ua-model': '',
'sec-ch-ua-wow64': '?0',
'sec-ch-ua-platform': '"Windows"',
'Accept': '*/*',
'X-Client-Data': 'CKW1yQEIhbbJAQiktskBCMS2yQEIqZ3KAQjb08oBCLD+ygEIlaHLAQjv8swBCN75zAEI5PrMAQjxgM0BCLKCzQEI7ILNAQjIhM0BCO+EzQEIt4XNAQ==',
'Sec-Fetch-Site': 'same-origin',
'Sec-Fetch-Mode': 'cors',
'Sec-Fetch-Dest': 'empty',
'host': 'www.google.com.hk',
'Cookie': '1P_JAR=2022-12-26-12; NID=511=eVLI1bG9nhyOZtqU14JBHm5Be00epdxfR4XmfQeehYyIkzgpXi6dbpNY75ZMVyS7aOjoM2oZ5WdoR8eNq6wi1-e_J0NeoyI0dtsHW-_8Ik4PGrqvuGHdcvVC03zTOEK2TY1FZL85Wimo_ZPIE3hGIrmGPSiel6-rRRW9lD30UPs'
}
response = requests.request("POST", url, headers=headers, data=payload)
print(response.text)
data:image/s3,"s3://crabby-images/14fc0/14fc0bbeb2478ac46ca2240add8615ff0ed25ab5" alt=""
对返回结果进行解析
data:image/s3,"s3://crabby-images/e7c07/e7c07bf3ac7b64b0de0bbaed438079589d877452" alt=""
data:image/s3,"s3://crabby-images/f83b2/f83b2985aa3f72c4ad75bc608ef6c8509be8b6a5" alt=""
完整代码
def Google_Translate(origin_string):
import requests
url = "https://www.google.com.hk/async/translate"
payload = "async=translate,sl:en,tl:zh-CN,st:{},id:1672056488960,qc:true,ac:true,_id:tw-async-translate,_pms:s,_fmt:pc".format(origin_string)
headers = {
'sec-ch-ua': '"Not?A_Brand";v="8", "Chromium";v="108", "Google Chrome";v="108"',
'DNT': '1',
'sec-ch-ua-mobile': '?0',
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36',
'sec-ch-ua-arch': '"x86"',
'sec-ch-ua-full-version': '"108.0.5359.125"',
'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8',
'sec-ch-ua-platform-version': '"10.0.0"',
'sec-ch-ua-full-version-list': '"Not?A_Brand";v="8.0.0.0", "Chromium";v="108.0.5359.125", "Google Chrome";v="108.0.5359.125"',
'sec-ch-ua-bitness': '"64"',
'sec-ch-ua-model': '',
'sec-ch-ua-wow64': '?0',
'sec-ch-ua-platform': '"Windows"',
'Accept': '*/*',
'X-Client-Data': 'CKW1yQEIhbbJAQiktskBCMS2yQEIqZ3KAQjb08oBCLD+ygEIlaHLAQjv8swBCN75zAEI5PrMAQjxgM0BCLKCzQEI7ILNAQjIhM0BCO+EzQEIt4XNAQ==',
'Sec-Fetch-Site': 'same-origin',
'Sec-Fetch-Mode': 'cors',
'Sec-Fetch-Dest': 'empty',
'host': 'www.google.com.hk',
'Cookie': '1P_JAR=2022-12-26-12; NID=511=eVLI1bG9nhyOZtqU14JBHm5Be00epdxfR4XmfQeehYyIkzgpXi6dbpNY75ZMVyS7aOjoM2oZ5WdoR8eNq6wi1-e_J0NeoyI0dtsHW-_8Ik4PGrqvuGHdcvVC03zTOEK2TY1FZL85Wimo_ZPIE3hGIrmGPSiel6-rRRW9lD30UPs'
}
response = requests.request("POST", url, headers=headers, data=payload)
def find_string_between_A_amd_B(string, string_A, string_B): # 查找两段字符串之间的字符
import re
regular = '{}(.*?){}'.format(string_A, string_B)
result = re.findall(regular, string)
return result
result = find_string_between_A_amd_B(response.text, '', '')
return result
result = Google_Translate('222')
print("result:", result)
data:image/s3,"s3://crabby-images/768a6/768a6c840259dc5f7592e83858c7c352931f3035" alt=""
data:image/s3,"s3://crabby-images/98518/985188ced67fdcdd3b3a4f0cddfa08201492df25" alt=""
#