91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python怎么用request庫實現翻譯接口

發布時間:2023-05-06 15:17:18 來源:億速云 閱讀:97 作者:iii 欄目:開發技術

本篇內容主要講解“Python怎么用request庫實現翻譯接口”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Python怎么用request庫實現翻譯接口”吧!

request庫的基本使用

安裝

要使用Python中的requests庫,首先需要使用pip安裝它。您可以在終端中運行以下命令來完成此操作:

pip install requests

使用

安裝庫后,您可以使用它來進行HTTP請求。以下是如何進行GET請求的示例:

import requests

response = requests.get('https://www.baidu.com')
print(response.text)

在此示例中,我們導入requests庫,然后使用get方法進行GET請求到https://www.baidu.com。服務器的響應存儲在response變量中,我們將響應文本打印到控制臺。

還可以將參數傳遞給get方法,以在請求中包含查詢參數:

import requests

params = {'key1': 'value1', 'key2': 'value2'}
response = requests.get('https://www.example.com', params=params)
print(response.url)

在此示例中,我們將查詢參數的字典傳遞給get方法的params參數。生成的URL將包括查詢參數,我們將URL打印到控制臺。

還可以使用post方法進行POST請求:

import requests

data = {'key1': 'value1', 'key2': 'value2'}
response = requests.post('https://www.example.com', data=data)
print(response.text)

在此示例中,我們將數據的字典傳遞給post方法的data參數。數據將在請求的正文中發送,我們將響應文本打印到控制臺。

開發自己的翻譯接口

分析百度翻譯

打開百度翻譯地址,然后按F12打開開發者模式,輸入翻譯的內容,點擊翻譯,通過下圖,可以清楚看到請求的地址和請求的參數

Python怎么用request庫實現翻譯接口

百度翻譯通過向https://fanyi.baidu.com/v2transapi發送post請求,發送的數據中只有sign是不斷變化的,搜索v2transapi發現sign字段是通過js通過你要發送的數據字符串進行加密得到的。

Python怎么用request庫實現翻譯接口

通過百度翻譯的js分析得出加密的關鍵代碼如下:

Python怎么用request庫實現翻譯接口

現在已經搞清楚了整個調用的流程,所有的參數都可以自己構造。這樣就可以寫代碼了。

寫接口代碼

1、為了防止請求失敗,需要模仿瀏覽器請求,在請求時加上請求頭,我們采用fake_useragent這個第三方庫,隨機生成不同的User-Agent。關鍵代碼如下:

from fake_useragent import UserAgent
headers = {'User-Agent': UserAgent().random}

2、生成sign參數,由于加密的js代碼我們看不明白,直接調用python的第三方庫執行js代碼,使用前需要安裝execjs庫,執行如下的代碼:

pip3 install PyExecJS

這個庫使用方法也很簡單,例如,上面我們已經把百度的加密js代碼已經提取出來了,并新建一個js文件,把內容復制進去。關鍵代碼如下:

    def generate_sign(self,query):
        try:
            if os.path.isfile("./baidu.js"):
                with open("./baidu.js", 'r', encoding="utf-8") as f:
                    baidu_js = f.read()
            ctx = execjs.compile(baidu_js)
            return ctx.call('b', query)
        except Exception as e:
            print(e)

先把js文件讀到緩存中,再通過execjs調用該對象。最后通過調用call方法執行js文件的里面的方法,其中b是對應js的方法,queryjsb方法的參數。

調用成功后,返回如下:

Python怎么用request庫實現翻譯接口

3、獲取token值,通過觀察百度翻譯頁面的源碼,發現token是存放在頁面中的,這樣我們就可以通過請求頁面獲取到token.

Python怎么用request庫實現翻譯接口

res = request.get("https://fanyi.baidu.com").content.decode()
token = re.findall(r"token: '(.*)',", res, re.M)[0]

4、到目前為止所有的請求參數已經有了,這樣我們就可以開始構造請求。核心代碼如下:

    url = 'https://fanyi.baidu.com/v2transapi'
    sign = generate_sign("你好")
    data = {
        "from": "zh",
        "to": 'en',
        "query": "你好",
        "transtype": "translang",
        "simple_means_flag": "3",
        "sign": sign,
        "token": self.token,
        "domain": "common"
    }
    res = requests.post(
        url=url,
        params={"from": "zh", "to": 'en'},
        data=data,
        headers = {
            'User-Agent': UserAgent().random,
        }
    )

    res.json().get("trans_result").get("data")[0].get("dst")

請求成功后,會返回如下圖:

Python怎么用request庫實現翻譯接口

通過實際的調用中發現不是每次請求成功的,所以需要多次進行請求,通過一個循環操作,當清楚成功就跳出循環,關鍵代碼如下:

        tryTimes = 0
        try:
            while tryTimes < 100:
                res = self.session.post(
                    url=url,
                    params={"from": fromLan, "to": toLan},
                    data=data,
                )
                if "trans_result" in res.text:
                    break
                tryTimes += 1
            return res.json().get("trans_result").get("data")[0].get("dst")

這樣我們就已經完成利用百度翻譯接口,做成自己的翻譯接口調用了。可以根據自己的需求采用FlaskFastapi開發API接口了。下面是全部的代

import requests
import execjs
import os
import re
import json
from loguru import logger
from fake_useragent import UserAgent

class Baidu_translate:
    
    def  __init__(self):
        self.session=request.Session()
        self.session.headers={
            'User-Agent': UserAgent( ).random,
            "Host":"fanyi.baidu.com",
            "X-Requested-With":"XMLHttpRequest",
            "sec-ch-ua":'"Not?A_Brand";="8","Chromium";v="108","Microsoft Edge";V="108",
            "sec-ch-ua-mobile":"?0",
            "Sec-Fetch-Dest":"document",
            "Sec-Fetch-Mode":"navigate",
            "Sec-Fetch-Site": "same-origin",
            "Sec-Fetch-User":"?1",
            "Connection":"keep-alive",
        }
        
        self.session.get("https://fanyi.baidu.com" )
        res = self.session.get("https://fanyi.baidu.com").content.decode( )
        self.token = re.findall(r"token: '(.*)',",res,re.M)[0]
        
    def generate_sign(self,query):
        try:
            if os.path.isfile("./baidu.js"):
                with open("./baidu.js",'r',encoding="utf-8") as f:
                    baidu_js = f.read( )
            ctx = execjs.compile(baidu_js)
            return ctx.call('b',query)
        except Exception as e:
            print(e)

   def lang_detect(self,src: str) -> str:
       url = "https://fanyi.baidu.com/langdetect"
       fromLan = self.session.post(url, data={"query": src}).json()["lan"]
       return fromLan

   def translate(self,query: str, tolan: str = "", fromLan: str = "") -> str:
       
       if fromLan == "":
           fromLan = self.lang_detect(query)
           
       if toLan == "":
           toLan = "zh" if fromLan != "zh" else "en"
           
       url = 'https://fanyi.baidu.com/v2transapi'
       sign = self.generate_sign(query)
       data = {
           "from" : fromLan,
           "to": toLan,
           "query": query,
           "transtype":"translang",
           "simple_means_flag":"3",
           "sign" : sign,
           "token": self.token,
           "domain":"common"
       }
       tryTimes = 0
       try:
           while tryTimes < 100:
               res = self.session.post(
                   url=url,
                   params={"from": fromLan,"to": toLan},
                   data=data,
               )
               if "trans_result" in res.text:
                  break
               tryTimes +=1
        return res.json().get("trans_result").get("data")[0].get("dst")
    except Exception as e:
        print(e)
              
def test():
    url ='https://fanyi.baidu.com/v2transapi'
    sign = generate_sign("你好")
    data = {
        "from":"zh",
        "to":' en',
        "query":"你好",
        "transtype":"translang",
        "simple_means_flag":"3",
        "sign": sign,
        "token": self.token,
        "domain": "common"
        }
    res = requests.post(
        url=url,
        params={"from": "zh","to":'en'},
        data=data,
        headers = {
            'User-Agent': UserAgent( ).random,
        }
    )
    
    res .json()
    
if _name__ == "__main__":
    baidu_tran = Baidu_Translate()
    sign = baidu_tran.generate_sign("你好")

到此,相信大家對“Python怎么用request庫實現翻譯接口”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

十堰市| 凌云县| 开鲁县| 锡林郭勒盟| 西充县| 错那县| 连州市| 安徽省| 萨嘎县| 安溪县| 泾源县| 玉环县| 屏山县| 阳曲县| 淅川县| 清涧县| 四子王旗| 临颍县| 昌宁县| 新竹市| 普陀区| 鹤山市| 安乡县| 始兴县| 肥城市| 密山市| 和林格尔县| 龙游县| 房产| 合江县| 横峰县| 兴化市| 西安市| 沅陵县| 宁武县| 哈密市| 河南省| 都江堰市| 庐江县| 南川市| 方山县|