1. 程式人生 > >【python爬蟲小實戰】python3.x用requests和bs4實現有道翻譯(中英文)

【python爬蟲小實戰】python3.x用requests和bs4實現有道翻譯(中英文)

一直用的是python3.x版本的,剛開始學爬蟲的時候學長給了我個爬有道翻譯的小程式,實現中英文翻譯,由於是用urllib庫的,當時也是剛接觸python,所以一臉懵逼,現在學了一個月了,回頭再看了一下,感覺很時間單,於是就用requests庫和bs4,加上json網頁解析,也寫 了個翻譯小程式,(感覺比用urllib程式碼要少的多,)其實開始requests.get的方法引數很懵逼,百度了一下,總算把這點弄明白。越發感覺python庫的強大

#python 爬蟲有道翻譯
import requests
from bs4 import BeautifulSoup
import json
while
True: content = input('請輸入要查詢的單詞/詞語(輸入0退出翻譯):') if content == '0': print('歡迎下次使用!') break url = 'http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&sessionFrom=null' headers = { 'User-Agent':'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/59.0.3071.115 Safari/537.36'
,'from':'AUTO', 'to':'AUTO', 'smartresult':'dict', 'client':'fanyideskweb', 'doctype':'json', 'version':'2.1', 'keyfrom':'fanyi.web', 'action':'FY_BY_ENTER', 'typoResult':'true', 'i':content ,'ue':'UTF-8'#設定翻譯支援中文
} res = requests.get(url,params = headers) soup = BeautifulSoup(res.text,'lxml') jd = json.loads(soup.text) print('翻譯結果:') for translate in jd['smartResult']['entries']: print(translate) print('\n')

退出測試
翻譯測試
程式碼很簡單,很容易就能明白的,歡迎大佬們測試(#滑稽)