使用python中的requests爬取百度翻译实现中英互译功能

话不多说,直接上代码 

# coding=utf-8
import requests
import json
import sys


class BaiduFanyi:
    def __init__(self, tran_str):
        self.tran_str = tran_str
        self.lang_detect_url = "https://fanyi.baidu.com/langdetect"
        self.trans_url = "https://fanyi.baidu.com/basetrans"
        self.headers = {
            "User-Agent": "Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/11.0 Mobile/15A372 Safari/604.1"}

    def parse_url(self, url, data):  # 1.2 发送post请求,获取响应
        r = requests.post(url, data=data, headers=self.headers)
        return json.loads(r.content.decode())

    def get_url(self, dict_response):
        ret = dict_response["trans"][0]["dst"]
        print("result is :", ret)

    def run(self):  # 实现主要逻辑
        # 1.获取语言类型
        # 1.1 准备post的url地址,post_data
        lang_detect_data = {"query": self.tran_str}
        # 1.2 发送post请求,获取响应
        lang = self.parse_url(self.lang_detect_url, lang_detect_data)["lan"]
        # 1.3 提取语言类型
        # 2.准备post的数据
        trans_data = {"query": self.tran_str, "from": "zh", "to": "en"} if lang == "zh" else {"query": self.tran_str,
                                                                                              "from": "en", "to": "zh"}
        # 3.发送请求,获取响应
        dict_response = self.parse_url(self.trans_url, trans_data)
        # 4.提取翻译的结果
        self.get_url(dict_response)


if __name__ == "__main__":
    trans_str = sys.argv[1]
    baidu_fanyi = BaiduFanyi(trans_str)
    baidu_fanyi.run()

代码上完后运行代码实现中英互译:

ps: 输入英文It's windy today.必须打引号,因为sys.argv[]是按照空格获取参数,如果不打引号,sys.argv[1]只能获取It's而非It's windy today. 

百度翻译原型:

猜你喜欢

转载自blog.csdn.net/qq_39198486/article/details/82749923