国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

Python爬蟲爬取有道實(shí)現(xiàn)翻譯功能

瀏覽:3日期:2022-07-04 09:22:25

準(zhǔn)備

首先安裝爬蟲urllib庫

pip install urllib

獲取有道翻譯的鏈接url

Python爬蟲爬取有道實(shí)現(xiàn)翻譯功能

需要發(fā)送的參數(shù)在form data里

Python爬蟲爬取有道實(shí)現(xiàn)翻譯功能

示例

import urllib.requestimport urllib.parseurl = ’http://fanyi.youdao.com/translate_o?smartresult=dict&smartresult=rule’data = {}data[’i’] = ’i love python’data[’from’] = ’AUTO’data[’to’] = ’AUTO’data[’smartresult’] = ’dict’data[’client’] = ’fanyideskweb’data[’salt’] = ’16057996372935’data[’sign’] = ’0965172abb459f8c7a791df4184bf51c’data[’lts’] = ’1605799637293’data[’bv’] = ’f7d97c24a497388db1420108e6c3537b’data[’doctype’] = ’json’data[’version’] = ’2.1’data[’keyfrom’] = ’fanyi.web’data[’action’] = ’FY_BY_REALTlME’data = urllib.parse.urlencode(data).encode(’utf-8’)response = urllib.request.urlopen(url,data)html = response.read().decode(’utf-8’)print(html)

運(yùn)行會(huì)出現(xiàn)50的錯(cuò)誤,這里需要將url鏈接的_o刪除掉

Python爬蟲爬取有道實(shí)現(xiàn)翻譯功能

刪除后運(yùn)行成功

Python爬蟲爬取有道實(shí)現(xiàn)翻譯功能

但是這個(gè)結(jié)果看起來還是太復(fù)雜,需要在進(jìn)行優(yōu)化

導(dǎo)入json,然后轉(zhuǎn)換成字典進(jìn)行過濾

import urllib.requestimport urllib.parseimport jsonurl = ’http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule’data = {}data[’i’] = ’i love python’data[’from’] = ’AUTO’data[’to’] = ’AUTO’data[’smartresult’] = ’dict’data[’client’] = ’fanyideskweb’data[’salt’] = ’16057996372935’data[’sign’] = ’0965172abb459f8c7a791df4184bf51c’data[’lts’] = ’1605799637293’data[’bv’] = ’f7d97c24a497388db1420108e6c3537b’data[’doctype’] = ’json’data[’version’] = ’2.1’data[’keyfrom’] = ’fanyi.web’data[’action’] = ’FY_BY_REALTlME’data = urllib.parse.urlencode(data).encode(’utf-8’)response = urllib.request.urlopen(url,data)html = response.read().decode(’utf-8’)req = json.loads(html)result = req[’translateResult’][0][0][’tgt’]print(result)

Python爬蟲爬取有道實(shí)現(xiàn)翻譯功能但是這個(gè)程序只能翻譯一個(gè)單詞,用完就廢了。于是我在進(jìn)行優(yōu)化

import urllib.requestimport urllib.parseimport jsondef translate(): centens = input(’輸入要翻譯的語句:’) url = ’http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule’ head = {}#增加請(qǐng)求頭,防反爬蟲 head[’User-Agent’] = ’Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.198 Safari/537.36’ data = {}#帶上from data的數(shù)據(jù)進(jìn)行請(qǐng)求 data[’i’] = centens data[’from’] = ’AUTO’ data[’to’] = ’AUTO’ data[’smartresult’] = ’dict’ data[’client’] = ’fanyideskweb’ data[’salt’] = ’16057996372935’ data[’sign’] = ’0965172abb459f8c7a791df4184bf51c’ data[’lts’] = ’1605799637293’ data[’bv’] = ’f7d97c24a497388db1420108e6c3537b’ data[’doctype’] = ’json’ data[’version’] = ’2.1’ data[’keyfrom’] = ’fanyi.web’ data[’action’] = ’FY_BY_REALTlME’ data = urllib.parse.urlencode(data).encode(’utf-8’) req = urllib.request.Request(url,data,head) response = urllib.request.urlopen(req) html = response.read().decode(’utf-8’) req = json.loads(html) result = req[’translateResult’][0][0][’tgt’] # print(f’中英互譯的結(jié)果:{result}’) return resultt = translate()print(f’中英互譯的結(jié)果:{t}’)

優(yōu)化完成,效果還行。

Python爬蟲爬取有道實(shí)現(xiàn)翻譯功能

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 阿城市| 平乡县| 贺兰县| 武川县| 泰来县| 河北区| 五峰| 十堰市| 荣昌县| 南投市| 宁远县| 东乡族自治县| 十堰市| 阳谷县| 额济纳旗| 凉城县| 新野县| 黄骅市| 平遥县| 静安区| 胶州市| 玉龙| 湘阴县| 文山县| 兰西县| 工布江达县| 高雄县| 聊城市| 永州市| 绥滨县| 小金县| 历史| 含山县| 澄城县| 手游| 阳江市| 米泉市| 崇明县| 阿鲁科尔沁旗| 竹溪县| 平和县|