如何修复在vsCode中运行的python代码,被抓取的数据是中文乱码,而不是直接在python空闲

问题描述 投票:0回答:1

我写了一段网页抓取工具代码,用于抓取有道字典进行翻译。在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中运行时,它是乱码。

python visual-studio-code web-crawler output
1个回答
0
投票

问题可能是终端的编码与IDLE中的编码不同,这导致了不同的结果。

如果你可以升级到Python 3.7那么可能会修复它,因为在该版本中使用更合理的默认值来终端编码。

© www.soinside.com 2019 - 2024. All rights reserved.