python 谷歌翻译 api_调用谷歌翻译API

python 谷歌翻译 api_调用谷歌翻译API在平时使用谷歌翻译的过程中 经常会遇到需要批量翻译大量文本的情景 这种时候需要调用谷歌翻译的 API 首先可以使用 python 库 googletransp 使用方法 fromgoogletr Translator service urls translate google cn sour

在平时使用谷歌翻译的过程中,经常会遇到需要批量翻译大量文本的情景,这种时候需要调用谷歌翻译的API

首先可以使用python库googletrans

pip install googletrans

#使用方法

from googletrans import Translator

translator = Translator(service_urls=[‘translate.google.cn’])

source = ‘我还是不开心!’

text = translator.translate(source,src=’zh-cn’,dest=’en’).text

print(text)

“i’m still not happy!”

但是在面对大规模需要翻译的句子时就会很慢,所以可以使用协程的方法。

这里我们使用了基于gevents库的grequests库。

仔细看了下googletrans库的核心代码,发现主要是构造一个url,然后发起get请求,得到一个json的结果,从中提取出翻译结果。

构造url的过程需要一个token,根据某些规则生成,所以为了方便还是调用googletrans的部分函数。

具体的参考代码如下:

这里是将德语(de)翻译成英语(en),代码中需要相应修改。

import grequests

import logging

import json

from googletrans import Translator

from googletrans.utils import format_json

headers = {‘User-Agent’:’Mozilla/5.0 (Windows NT 10.0; Win64; x64)’}

translator = Translator(service_urls=[‘translate.google.cn’])

logging.basicConfig(level = logging.INFO,format = ‘%(asctime)s – %(name)s – %(levelname)s – %(message)s’,filename=’log.txt’)

logger = logging.getLogger()

def exception_handler(request, exception):

logger.warning(‘exception when at %s :%s’,request.url,exception)

def work(urls):

reqs = (grequests.get(u,verify=True, allow_redirects=True, timeout=4) for u in urls)

res = grequests.map(reqs, exception_handler=exception_handler,size=20)

return res

def totaltranslate():

file2 = open(‘de2en_en.txt’,mode=’a’,encoding=’utf-8′)

with open(‘de.txt’,mode=’r’,encoding=’utf-8′) as f:

urls = []

num = 0

for line in f:

num+=1

line = line.strip()

token = translator.token_acquirer.do(line)

url=”https://translate.google.cn/translate_a/single?client=t&sl=de&tl=en&hl=en&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&otf=1&ssel=3&tsel=0&kc=1&tk={0}&q={1}”.format(token,line)

urls.append(url)

if len(urls) >= 50:

res = work(urls)

for r in res:

if hasattr(r,’status_code’):

if r.status_code == 200:

try:

a=format_json(r.text)

target = ”.join([d[0] if d[0] else ” for d in a[0]])

source = ”.join([d[1] if d[1] else ” for d in a[0]])

except Exception as e:

logger.error(‘when format:%s’,e)

logger.error(‘%s\n%s’,r.text)

source = ”

target = ”

if len(source) != 0 and len(target) != 0:

file2.write(target+’\n’)

else:

file2.write(‘\n’)

else:

file2.write(‘\n’)

urls = []

logger.info(‘finish 50 sentence, now at %s’,num)

file2.close()

def sentencetranslate(line):

line = line.strip()

text = translator.translate(line,src=’de’,dest=’en’).text

return text

def completetranslate():

file1 = open(‘de2en_en.txt’,mode=’r’,encoding=’utf-8′)

file2 = open(‘new_de2en_en.txt’,mode=’a’,encoding=’utf-8′)

i = 1

with open(‘de.txt’,mode=’r’,encoding=’utf-8′) as f:

for line in f:

t = file1.readline()

if len(t) == 1:#’only \n’

text = sentencetranslate(line)

file2.write(text+’\n’)

else:

file2.write(t)

i += 1

if i%100 == 0:

print(i)

file1.close()

file2.close()

if __name__ == “__main__”:

totaltranslate()

completetranslate()

totaltranslate()以及翻译了大部分的句子,但是可能因为某些原因有一些句子没有翻译,所以还需要completetranslate()来补全翻译结果。

在grequests.map()中size设置为20的情况下,平均每秒翻译20句。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/215290.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 下午2:14
下一篇 2026年3月18日 下午2:15


相关推荐

  • 你的Wi-Fi 还安全吗?全球重大漏洞WPA2 KRACK 详细分析报告

    你的Wi-Fi 还安全吗?全球重大漏洞WPA2 KRACK 详细分析报告近日,Wi-Fi加密协议被曝光存在重大安全漏洞,用于保护Wi-Fi网络安全的WPA2安全加密协议已被黑客破解。这种被称作“Krack”(密钥重装攻击)攻击意味着用户连接的绝大多数Wi-Fi已经不安全了,包括家中的路由器Wi-Fi,都存在被盗号的风险。攻击者可通过此漏洞获取万能密钥来访问WPA2网络,从而窃听用户的通讯信息。究竟这个漏洞是由哪些缺陷引起的?会对用户造成什么影响?作为技术人的我们,又…

    2022年5月4日
    51
  • 怎样发外链,使网站能快速收录,秒收录

    怎样发外链,使网站能快速收录,秒收录本文来自:优优蜘蛛池(http://www.zhizhuchi.vip)1.首先就是大家都熟知的百度网站提交2.利数桥带族用的周边产品添加网站的外链吸引蜘蛛进入你的网站。3.写一篇原创文章加上自己的网站链接后投稿到大型的站长网站。4.到高权重的论坛注册账号,这个人签名里添加上自己网站的超链接,发发贴,顶顶贴,就能无形中增加了。2:利用公司名字和地址在分类信息做外链。3:利用论坛昵称做高质量外链。4:在帖子内容中巧带二级域名链接。SEO优化之网站怎么实现百度秒收录何谓”秒收录”?大家可以经常

    2022年5月17日
    56
  • VS Code 使用国产大模型 MiniMax M2 教程

    VS Code 使用国产大模型 MiniMax M2 教程

    2026年3月16日
    2
  • Java安装教程

    Java安装教程今日份闲来无事,整理了一些Java的数据库安装教程,请君共阅:其实主要就分三部分:1:下载Java的安装包并安装Java2:电脑环境设置3:验证Java是否安装成功第一步:下载Java的安装包并安装Java:1.首先去官网现在JAVA安装包JAVA安装包下载地址:https://www.oracle.com/technetwork/java/javase/downloads/index.html(官网地址),打开链接后,如下图:2.点击下面椭圆圈起来的“Download”按钮。3:跳转到

    2022年7月9日
    20
  • 手把手较你编写Python爬虫程序-不要干坏事哦

    手把手较你编写Python爬虫程序-不要干坏事哦首先我们知道互联网简单来说是由一个个站点和网络设备组成的大网 我们通过浏览器访问站点 站点把 HTML JS CSS 代码返回给浏览器 这些代码经过浏览器解析 渲染 将丰富多彩的网页呈现我们眼前 如果我们把互联网比作一张大的蜘蛛网 数据便是存放于蜘蛛网的各个节点 而爬虫就是一只小蜘蛛 沿着网络抓取自己的猎物 数据 爬虫指的是 向网站发起请求 获取资源后分析并提取有用数据的程序 从技术层面来说就是通过程序模拟浏览器请求站点的行为 把站点返回的 HTML 代码 JSON 数据 二进制

    2026年3月16日
    2
  • mysql是什么类型数据库_MySQL是一种

    mysql是什么类型数据库_MySQL是一种在学习MySQL之前,首先需要了解数据库和SQL。如果您已经知道数据库和SQL,那么可以直接跳转到下一章节的学习。1.数据库简介当您想收听最喜欢的歌曲时,可以从智能手机上打开播放列表。在这种情

    2022年8月1日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号