我写了一段网页抓取工具代码,用于抓取有道字典进行翻译。在vscode中运行时,输出是乱码。当直接在python空闲时运行时,输出正常。我该怎么办?
我试图将编码模式设置为utf-8,gb2312或gbk,但它不起作用。
from urllib import request
from urllib import parse
import json
content = input("请输入你要查找的字:")
url = " http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule"
data = {}
data['i'] = content
data['from'] = 'AUTO'
data['to'] = 'AUTO'
data['smartresult'] = 'dict'
data['client'] = 'fanyideskweb'
data['doctype'] = 'json'
data['version'] = '2.1'
data['keyfrom'] = 'fanyi.web'
data['action'] = 'FY_BY_CLICKBUTTION'
data = parse.urlencode(data).encode('utf-8')
header = {}
header['Referer'] = 'http://fanyi.youdao.com/?keyfrom=dict2.index'
header['User-Agent'] = 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.25 Safari/537.36 Core/1.70.3650.400 QQBrowser/10.4.3341.400'
req = request.Request(url = url, headers = header)
response = request.urlopen(req, data = data)
result_str = response.read().decode('utf-8')
result_dict = json.loads(result_str)
print(result_dict)
print('翻译的结果是:%s' % result_dict['translateResult'][0][0]['tgt'])
如果我输入'love',我希望'love'的输出为'love'。当我在python空闲时运行上面的代码时,这是正常的。但是在vscode中运行时,它是乱码。
问题可能是终端的编码与IDLE中的编码不同,这导致了不同的结果。
如果你可以升级到Python 3.7那么可能会修复它,因为在该版本中使用更合理的默认值来终端编码。