Hyg123456 发表于 2020-8-19 23:35:50

有道爬虫添加User-Agent后不能翻译

我刚开始跟着小甲鱼做,没有添加User-Agent的时候可以翻译,添加了User-Agent之后,一直提示“ 您的请求来源非法,商业用途使用请关注有道翻译API官方网站“有道智云”: http:\/\/ai.youdao.com”

Twilight6 发表于 2020-8-19 23:48:18

本帖最后由 Twilight6 于 2020-8-19 23:49 编辑



不懂你的代码是什么样的,按正常来说如果没加 UA 那更不可能翻译成功吧

参考下这个代码吧:

import urllib.request
import urllib.parse
import json
import time
while True:
    content=input('请输入要翻译的内容(如果结束请输入Esc):')
    if content=='Esc':
      break
    headers={}
    headers['User-Agent']='Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.25 Safari/537.36 Core/1.70.3706.400 SLBrowser/10.0.4040.400'
    url='http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule'
    data={'i':content,
      'from':'AUTO',
      'to':'AUTO',
      'smartresult':'dict',
      'client':'fanyideskweb',
      'salt':'15966771704905',
      'sign': '8634c91db8413ef4cfbe684fd030d518',
      'ts': '1596677170490',
      'bv': 'd16528ec6ead722121051f646932f6ab',
      'doctype': 'json',
      'version': '2.1',
      'keyfrom': 'fanyi.web',
      'action':'FY_BY_REALTlME'}
    data=urllib.parse.urlencode(data).encode('utf-8')
    req = urllib.request.Request(url,data=data,headers=headers)
    response=urllib.request.urlopen(req)
    html=response.read().decode('utf-8')
    target=json.loads(html)
    target=target['translateResult']['tgt']
    print(content+' 翻译为:'+target)
    time.sleep(1)

Hyg123456 发表于 2020-8-19 23:55:14

Twilight6 发表于 2020-8-19 23:48
不懂你的代码是什么样的,按正常来说如果没加 UA 那更不可能翻译成功吧

参考下这个代码吧:

我是照着小甲鱼之前的代码敲的,已经可以翻译成功了,但是添加User-Agent之后就一直提示商业用途
req = urllib.request.Request(url,data=data,headers=headers)
我的是req = urllib.request.Request(url,data,head),上面已经定义好参数了
req=urllib.request.Request(url,data)
    req.add_header('User-Agent','Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.116 Safari/537.36' )   
    response = urllib.request.urlopen(req)

Twilight6 发表于 2020-8-19 23:55:47

Hyg123456 发表于 2020-8-19 23:55
我是照着小甲鱼之前的代码敲的,已经可以翻译成功了,但是添加User-Agent之后就一直提示商业用途
req =...

发完整代码

Hyg123456 发表于 2020-8-20 13:51:27

Twilight6 发表于 2020-8-19 23:55
发完整代码

能翻译了,昨晚不行,今天可以了{:10_261:}{:10_247:}

Twilight6 发表于 2020-8-20 13:59:12

Hyg123456 发表于 2020-8-20 13:51
能翻译了,昨晚不行,今天可以了

问题解决了的话,就设置下最佳答案吧~
页: [1]
查看完整版本: 有道爬虫添加User-Agent后不能翻译