Python 谷歌翻译API 无js代码

Google-Translation-API

谷歌翻译API

在网上发现该 API 后通过, 将其中的 JS 转为了 Python

一些示例

print(cn_to_en("中文"))

[[['Chinese', '中文', None, None,
2], [None, None, None, 'Zhōngwén']], [['名词', ['Chinese'], [['Chinese', ['中文', '汉语', '华人', '华
语', '汉'], None, 0.56094915]], '
中文', 1]], 'zh-CN', None, None, [['中文', None, [['Chinese', 1000,
True, False]], [[0, 2]], '中文', 0, 0]], 0.58841187, [], [['zh-CN',
'ja'], None, [0.58841187, 0.41158813], ['zh-CN', 'ja']]]

下面两端代码顺序放在一起即可

Github 可以来个 star 吗?😚

token 部分

def int_overflow(val):
    maxint = 2147483647
    if not -maxint-1 <= val <= maxint:
        val = (val + (maxint + 1)) % (2 * (maxint + 1)) - maxint - 1
    return val

def unsigned_right_shitf(n,i):
    n &= 0xffffffff
    return n >> i

def TL(a):
    k = ""
    b = 406644
    b1 = 3293161072

    _b = "+-a^+6"
    Zb = "+-3^+b+-f"

    e = []
    for g in range(len(a)):
        m = ord(a[g])
        if 128 > m :
            e.append(m)
        else:
            if 2048 > m:
                e.append(m >> 6 | 192)
            else:
                if (55296 == (m & 64512)) and (g + 1) < len(a) and (56320 == ord(a[g + 1]) & 64512):
                    m = 65536 + ((m & 1023) << 10) + ord(a[g]) & 1023
                    e.append(m >> 18 | 240)
                    e.append(m >> 12 & 63 | 128)                    
                else:
                    e.append(m >> 12 | 224)
                    e.append(m >> 6 & 63 | 128)
                    e.append(m & 63 | 128)
    
    a = b
    for f in range(len(e)):
        a += e[f]
        a = RL(a, _b)
    a = RL(a, Zb)
    a = a & 0xffffffff if 0 > a else a
    a = a ^ b1
    if 0 > a:
        a = (a & 2147483647) + 2147483648
    a %= 1E6
    float_part = str(int((int(a) ^ int(b))))
    return f"{int(a)}.{float_part}"

def RL(a, b):
    t = "a"; 
    Yb = "+"; 
    c = 0
    while c < len(b) - 2:
        d = b[c+2]
        d = ord(d[0])-87 if d >= t else int(d)
        d = unsigned_right_shitf(a, d) if b[c+1] == Yb else int_overflow(a<<d)
        a = a + int_overflow(d&0xffffffff) if b[c] == Yb else int_overflow(a^d)
        c += 3

    return a

请求部分

def buildUrl(content, tk, tl):  
        baseUrl = 'http://translate.google.cn/translate_a/single'
        baseUrl += '?client=webapp&'
        baseUrl += 'sl=auto&'
        baseUrl += 'tl=' + str(tl) + '&'
        baseUrl += 'hl=zh-CN&'
        baseUrl += 'dt=at&'
        baseUrl += 'dt=bd&'
        baseUrl += 'dt=ex&'
        baseUrl += 'dt=ld&'
        baseUrl += 'dt=md&'
        baseUrl += 'dt=qca&'
        baseUrl += 'dt=rw&'
        baseUrl += 'dt=rm&'
        baseUrl += 'dt=ss&'
        baseUrl += 'dt=t&'
        baseUrl += 'ie=UTF-8&'
        baseUrl += 'oe=UTF-8&'
        baseUrl += 'clearbtn=1&'
        baseUrl += 'otf=1&'
        baseUrl += 'pc=1&'
        baseUrl += 'srcrom=0&'
        baseUrl += 'ssel=0&'
        baseUrl += 'tsel=0&'
        baseUrl += 'kc=2&'
        baseUrl += 'tk=' + str(tk) + '&'
        baseUrl += 'q=' + content
        return baseUrl

def en_to_cn(txt):
    tl = "zh-CN"  # tl is the target language 
    tk = TL(txt)

    content = urllib.parse.quote(txt)
    url = buildUrl(content, tk, tl)
    headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:23.0) Gecko/20100101 Firefox/23.0'}
    r = requests.get(url,headers=headers,timeout=3)
    r_json = json.loads(r.text)
    return r_json

def cn_to_en(txt):
        tl = "en" # tl is the target language 
        tk = TL(txt)

        content = urllib.parse.quote(txt)
        url = buildUrl(content, tk,tl) 
        headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:23.0) Gecko/20100101 Firefox/23.0'}
        r = requests.get(url,headers=headers,timeout=3)
        r_json = json.loads(r.text)
        return r_json


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值