Googleからのネットワーク変換用のPython(V3.7)で(2019年8月5日)翻訳

ウェブページの翻訳の多くを使用し、私はGoogleの翻訳は、最近非常に専門的なPythonの爬虫類を学んだので、Googleの翻訳のアイデアを実現するためにクローラが使用されました。

まず、URL、Googleの翻訳を開けます。https://translate.google.cn/

HTTPS :? //Translate.google.cn/translate_a/singleクライアント= Webアプリケーション&SL =オート&TL = ZH-CN&HL = ZH-CN&DT = AT&DT = BD&DT = EX&DT = LD&DT = MD&DT =:F12キーを押して、ネットワーク、ディスカバリ要求のURLを参照してください。 QCA&DT = RW&DT = RM&DT = SS&DT = T&OTF = 1&SSEL = 0&TSEL = 0&KC = 1&TK = 247702.353673&Q =%E6%88%91%E6%の98%AFがすでにSL =オート多くの情報を見ることができる含ま&TL = ZH-CN&HL = ZH-CNこれらは、言語翻訳の選択であり、良いかクロール、取得する方法を要求します。

その後、これはデータを要求することであることを理解しやすいように、我々はテキストを翻訳する入力したq個のデータ項目を、要求に含まれる情報のURLクエリ文字列パラメータの最終を見下ろすと、

 データTKは、それが他のテキストを翻訳する際に、ランダムに生成されたjsファイル、およびテキスト入力と関連して、そのページを知って現実的ではない発見された、私はコピーして、このデータを貼り付ける最初のもあります。この目的のために、我々は、JSは、Googleの翻訳を提出取得する必要があります。前記TK上のコードは次のとおりです。

function TL(a) {
        var k = "";
        var b = 406644;
        var b1 = 3293161072;

        var jd = ".";
        var $b = "+-a^+6";
        var Zb = "+-3^+b+-f";

        for (var e = [], f = 0, g = 0; g < a.length; g++) {
            var m = a.charCodeAt(g);
            128 > m ? e[f++] = m : (2048 > m ? e[f++] = m >> 6 | 192 : (55296 == (m & 64512) && g + 1 < a.length && 56320 == (a.charCodeAt(g + 1) & 64512) ? (m = 65536 + ((m & 1023) << 10) + (a.charCodeAt(++g) & 1023),
            e[f++] = m >> 18 | 240,
            e[f++] = m >> 12 & 63 | 128) : e[f++] = m >> 12 | 224,
            e[f++] = m >> 6 & 63 | 128),
            e[f++] = m & 63 | 128)
        }
        a = b;
        for (f = 0; f < e.length; f++) a += e[f],
        a = RL(a, $b);
        a = RL(a, Zb);
        a ^= b1 || 0;
        0 > a && (a = (a & 2147483647) + 2147483648);
        a %= 1E6;
        return a.toString() + jd + (a ^ b)
    };

    function RL(a, b) {
        var t = "a";
        var Yb = "+";
        for (var c = 0; c < b.length - 2; c += 3) {
            var d = b.charAt(c + 2),
            d = d >= t ? d.charCodeAt(0) - 87 : Number(d),
            d = b.charAt(c + 1) == Yb ? a >>> d: a << d;
            a = b.charAt(c) == Yb ? a + d & 4294967295 : a ^ d
        }
        return a
    }

还是比较复杂的,我们通过python中的execjs模块来编译这部分代码,命名为HandleJs.py:

import execjs

class Py4Js():

    def __init__(self):
        self.ctx = execjs.compile("""
        function TL(a) {
        var k = "";
        var b = 406644;
        var b1 = 3293161072;

        var jd = ".";
        var $b = "+-a^+6";
        var Zb = "+-3^+b+-f";

        for (var e = [], f = 0, g = 0; g < a.length; g++) {
            var m = a.charCodeAt(g);
            128 > m ? e[f++] = m : (2048 > m ? e[f++] = m >> 6 | 192 : (55296 == (m & 64512) && g + 1 < a.length && 56320 == (a.charCodeAt(g + 1) & 64512) ? (m = 65536 + ((m & 1023) << 10) + (a.charCodeAt(++g) & 1023),
            e[f++] = m >> 18 | 240,
            e[f++] = m >> 12 & 63 | 128) : e[f++] = m >> 12 | 224,
            e[f++] = m >> 6 & 63 | 128),
            e[f++] = m & 63 | 128)
        }
        a = b;
        for (f = 0; f < e.length; f++) a += e[f],
        a = RL(a, $b);
        a = RL(a, Zb);
        a ^= b1 || 0;
        0 > a && (a = (a & 2147483647) + 2147483648);
        a %= 1E6;
        return a.toString() + jd + (a ^ b)
    };

    function RL(a, b) {
        var t = "a";
        var Yb = "+";
        for (var c = 0; c < b.length - 2; c += 3) {
            var d = b.charAt(c + 2),
            d = d >= t ? d.charCodeAt(0) - 87 : Number(d),
            d = b.charAt(c + 1) == Yb ? a >>> d: a << d;
            a = b.charAt(c) == Yb ? a + d & 4294967295 : a ^ d
        }
        return a
    }
    """)

    def getTk(self,text):
        return self.ctx.call("TL",text)

然后新建Translator-google.py,导入自己编写的库:

import requests
from HandleJs import Py4Js


def translate(lan_From,lan_To,tk, text):
    param = {'tk': tk, 'q': text}
    r = requests.get('http://translate.google.cn/translate_a/single?client=t&sl=auto&tl='+lan_To+'&hl='+lan_From+'&dt=at&dt=bd&dt=ex&dt=ld&dt=md&dt=qca&dt=rw&dt=rm&dt=ss&dt=t&ie=UTF-8&oe=UTF-8&clearbtn=1&otf=1&pc=1&srcrom=0&ssel=0&tsel=0&kc=1', params=param)
    text=r.json()
    result=text[0][0][0] #返回的时关于翻译文本和翻译语种的列表
    print(result)

if __name__ == "__main__":
    lan_From=input('Please enter which language you want to translate from(default:auto):')
    lan_To = input('Please enter which language you want to translate to:')
    text=input('Please enter your words for translating:')
    js = Py4Js()
    tk = js.getTk(text)
    translate(lan_From,lan_To,tk,text)

运行结果如下:

这里选择不同翻译语言需要输入谷歌翻译内置的语言缩写,如中文是zh-CN,日文是ja,英文是en等。

后续会添加图形界面,实现真正的人机交互。

 

おすすめ

転載: www.cnblogs.com/raccoonx95/p/11303543.html