運(yùn)行環(huán)境: python 3.6.0
創(chuàng)新互聯(lián)是一家專注于網(wǎng)站制作、做網(wǎng)站與策劃設(shè)計(jì),蔡甸網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)十多年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:蔡甸等地區(qū)。蔡甸做網(wǎng)站價(jià)格咨詢:18980820575今天處于練習(xí)的目的,就用 python 寫了一個(gè)百度翻譯,是如何做到的呢,其實(shí)呢就是拿到接口,通過(guò)這個(gè)接口去訪問(wèn),不過(guò)中間確實(shí)是出現(xiàn)了點(diǎn)問(wèn)題,不過(guò)都解決掉了
先晾圖后晾代碼
運(yùn)行結(jié)果:
代碼:
# -*- coding: utf-8 -*- """ 功能:百度翻譯 注意事項(xiàng):中英文自動(dòng)切換 """ import requests import re class Baidu_Translate(object): def __init__(self, query_string): self.query_string = query_string self.url_1 = 'https://fanyi.baidu.com/sug' # self.url = 'https://fanyi.baidu.com/v2transapi' # 這里不能用這個(gè)地址,因?yàn)閷?duì)方采用了反爬蟲措施,訪問(wèn)這個(gè)地址是人家是不會(huì)給你任何數(shù)據(jù)的 self.url_0 = 'https://fanyi.baidu.com/transapi' self.zh_pattern = re.compile('[\u4e00-\u9fa5]+') self.headers = { 'Accept': '* / *', 'Accept - Encoding': 'gzip, deflate', 'Accept - Language': 'zh-CN, zh; q=0.9', 'Connection': 'keep - alive', 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8', 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/72.0.3626.121 Safari/537.36', 'X-Requested-With': 'XMLHttpRequest', } def get_post_data(self): """ 拿到 post 請(qǐng)求上傳的參數(shù),并判斷輸入類型并予以返回 :return: 查詢?cè)~ """ if re.search(pattern=self.zh_pattern, string=self.query_string): # 輸入的內(nèi)容含有中文,則判別其為中文輸入 return { "from": "zh", "to": "en", "kw": self.query_string, # 模糊查詢 url_1關(guān)鍵詞 "query": self.query_string, # 精準(zhǔn)查詢 url_0關(guān)鍵詞 } else: return { "from": "en", "to": "zh", "kw": self.query_string, # 模糊查詢 url_1關(guān)鍵詞 "query": self.query_string, # 精準(zhǔn)查詢 url_0關(guān)鍵詞 } def request_translate(self): """ 向百度請(qǐng)求 json 數(shù)據(jù) :return: 向百度請(qǐng)求的 json 數(shù)據(jù) """ data = self.get_post_data() try: response_0 = requests.request(method="post", url=self.url_0, headers=self.headers, data=data).json() except Exception: # 進(jìn)行數(shù)據(jù)請(qǐng)求的任何異常處理 response_0 = '' try: response_1 = requests.request(method="post", url=self.url_1, headers=self.headers, data=data).json() except Exception: # 進(jìn)行數(shù)據(jù)請(qǐng)求的任何異常處理 response_1 = '' return response_0, response_1 def parse_translate_data(self): """ 數(shù)據(jù)解析,將請(qǐng)求到的翻譯內(nèi)容解析并輸出 :return: None """ response_0 = self.request_translate()[0] response_1 = self.request_translate()[1] # item = response_0 if response_0: item = response_0.get('data')[0].get('dst') print('key word:', self.query_string, '\t', 'translate:', item) if response_1: data = response_1.get('data') print() for item in data[:1]: # 長(zhǎng)度一般為5,這里只保留其釋義 print('key word: \t[ {key} ]'.format(key=item.get('k'))) print('value: \t\t[ {value} ]'.format(value=item.get('v'))) print() # print(response_1.get('data')) def main(): """ 主函數(shù) :return: None """ while True: try: query_keywords = input("""請(qǐng)輸入您要翻譯的內(nèi)容 [ 輸入四個(gè)'0'退出 ] : """) if query_keywords == "0000": # 如果輸入四個(gè) '0',退出小程序 print('########## 您已成功退出百度翻譯 ##########') break else: baidu = Baidu_Translate(query_string=query_keywords) baidu.parse_translate_data() except Exception as e: print('請(qǐng)求出錯(cuò),請(qǐng)重試', e.args) if __name__ == '__main__': main()
網(wǎng)站標(biāo)題:基于python實(shí)現(xiàn)百度翻譯功能-創(chuàng)新互聯(lián)
標(biāo)題來(lái)源:http://www.muchs.cn/article8/dhjcop.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、網(wǎng)站策劃、服務(wù)器托管、定制開發(fā)、網(wǎng)站收錄、Google
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容