使用百度翻译API或腾讯翻译API做一个小翻译工具

前言

书到用时方恨少,只能临时抱佛脚。英文pdf看不懂,压根看不懂。正好有百度翻译API和腾讯翻译API,就利用两个API自己写一个简单的翻译工具,充分利用资源,用的也放心。

前期准备

关键肯定是两大厂的翻译API,咱们只是做一个简单的应用,所以还没有API的同学可以申请一下。百度翻译API每个月有100万字符的免费额度,腾讯翻译API每个月有500万字符的免费额度,均指的是文本翻译。

百度翻译开放平台

腾讯云API

简单申请一下,获得两家或一家的id和key即可。

使用Python调用API

调用百度API:

利用百度翻译官方提供的调用demo,改写了一个包装类(Baidu_Text_transAPI.py),方便我们后续的调用。

包装类:

import requests
import random
from hashlib import md5


def make_md5(s, encoding='utf-8'):
    return md5(s.encode(encoding)).hexdigest()


class BaiduAPI:
    endpoint = 'http://api.fanyi.baidu.com'
    path = '/api/trans/vip/translate'
    url = endpoint + path

    def __init__(self):
        self._appid = None
        self._appkey = None

    @property
    def appid(self):
        return self._appid

    @appid.setter
    def appid(self, app_id):
        self._appid = app_id

    @property
    def appkey(self):
        return self._appkey

    @appkey.setter
    def appkey(self, app_key):
        self._appkey = app_key

    def translate(self, text, from_lang='auto', to_lang='zh'):
        salt = random.randint(32768, 65536)
        sign = make_md5(self.appid + text + str(salt) + self.appkey)

        # Build request
        headers = {'Content-Type': 'application/x-www-form-urlencoded'}
        payload = {'appid': self.appid, 'q': text, 'from': from_lang, 'to': to_lang, 'salt': salt, 'sign': sign}

        # Send request
        r = requests.post(self.url, params=payload, headers=headers)
        result = r.json()

        # Show response
        # print(json.dumps(result, indent=4, ensure_ascii=False))
        return result["trans_result"][0]["dst"]

调用示例:

from Baidu_Text_transAPI import BaiduAPI

baidu_api = BaiduAPI()
baidu_api.appid = "xxxxxxxxx"
baidu_api.appkey = "xxxxxxxxx"
text = "hello"
print(baidu_api.translate(text))  # 剩余两个参数可以使用默认值,也可以指定

调用腾讯翻译API:

腾讯翻译官方提供了一个SDK,方便我们更加方便的调用,所以只需要简单的封装一下即可(Tencent_Text_transAPI.py)。

封装类:

from tencentcloud.common import credential
from tencentcloud.tmt.v20180321 import tmt_client, models


class TencentAPI:

    def __init__(self):
        self._cred = None
        self._client = None
        self._secret_id = None
        self._secret_key = None

    @property
    def secret_id(self):
        return self._secret_id

    @secret_id.setter
    def secret_id(self, s_id):
        self._secret_id = s_id

    @property
    def secret_key(self):
        return self._secret_key

    @secret_key.setter
    def secret_key(self, s_key):
        self._secret_key = s_key

    def create_client(self):
        # 设置API密钥和地域
        self._cred = credential.Credential(self.secret_id, self.secret_key)
        self._client = tmt_client.TmtClient(self._cred, "ap-guangzhou")

    def translate(self, text: str, from_lang='auto', to_lang='zh'):
        request = models.TextTranslateRequest()
        request.SourceText = text
        request.Source = from_lang
        request.Target = to_lang
        request.ProjectId = 0

        response = self._client.TextTranslate(request)
        return response.TargetText

调用示例:

from Tencent_Text_transAPI import TencentAPI

tencent_api = TencentAPI()
tencent_api.secret_id = "xxxxxxxxx"
tencent_api.secret_key = "xxxxxxxxx"
text = "hello"
print(tencent_api.translate(text))  # 剩余两个参数可以使用默认值,也可以指定

使用PyQt构建一个简单的页面

翻译的核心关键——调用API,已经熟悉了这个流程,那么接下来就是构建一个简单的页面(demo_config_json.py),方便使用。

界面完整代码:

import json
import sys
import time

import pyperclip
from PyQt5.QtCore import Qt, QThread, pyqtSignal
from PyQt5.QtGui import QIcon
from PyQt5.QtWidgets import QApplication, QWidget, QComboBox, QLabel, QTextEdit, QPushButton, QVBoxLayout, \
    QHBoxLayout

from Baidu_Text_transAPI import BaiduAPI
from Tencent_Text_transAPI import TencentAPI


class Worker(QThread):
    prev_text = pyqtSignal(str)
    pre_value = pyperclip.paste()  # 初始化

    def run(self):
        while True:
            # 读取剪贴板内容
            curr_text = pyperclip.paste()
            # print(self.pre_value)
            if curr_text != self.pre_value:
                # print([curr_text])
                self.prev_text.emit(curr_text)
            # 每1秒检查一次剪贴板内容
            time.sleep(1)


def read_json_file(file_path):
    with open(file_path, 'r') as f:
        data = json.load(f)
    return data


class Translator(QWidget):
    def __init__(self):
        super().__init__()
        self.th = None
        self.translateButton = None
        self.outputTextEdit = None
        self.outputLabel = None
        self.inputTextEdit = None
        self.inputLabel = None
        self.translatorComboBox = None
        self.translatorLabel = None
        self.baidu_api = None
        self.tencent_api = None
        self.tmp = None
        self.config = read_json_file('config.json')
        self.init_ui()

    def init_ui(self):
        self.setWindowTitle('翻译工具')
        self.setWindowIcon(QIcon('icon.png'))
        # 上方选择框
        self.translatorLabel = QLabel('翻译API:')
        self.translatorComboBox = QComboBox()

        # 百度翻译API设置
        self.translatorComboBox.addItem('百度翻译')
        self.baidu_api = BaiduAPI()
        self.baidu_api.appid = self.config['BaiduAPI']['id']
        self.baidu_api.appkey = self.config['BaiduAPI']['key']

        # 腾讯翻译API设置
        self.translatorComboBox.addItem('腾讯翻译')
        self.tencent_api = TencentAPI()
        self.tencent_api.secret_id = self.config['TencentAPI']['id']
        self.tencent_api.secret_key = self.config['TencentAPI']['key']
        self.tencent_api.create_client()

        translator_layout = QHBoxLayout()
        translator_layout.addWidget(self.translatorLabel)
        translator_layout.addWidget(self.translatorComboBox)

        # 中部输入输出框
        self.inputLabel = QLabel('输入文本:')
        self.inputTextEdit = QTextEdit()
        self.outputLabel = QLabel('翻译结果:')
        self.outputTextEdit = QTextEdit()
        input_output_layout = QHBoxLayout()
        input_output_layout_left = QVBoxLayout()
        input_output_layout_left.addWidget(self.inputLabel)
        input_output_layout_left.addWidget(self.inputTextEdit)
        input_output_layout_right = QVBoxLayout()
        input_output_layout_right.addWidget(self.outputLabel)
        input_output_layout_right.addWidget(self.outputTextEdit)
        input_output_layout.addLayout(input_output_layout_left)
        input_output_layout.addLayout(input_output_layout_right)

        # 下方翻译按钮
        self.translateButton = QPushButton('翻译')
        translate_layout = QHBoxLayout()
        translate_layout.addStretch(1)
        translate_layout.addWidget(self.translateButton)
        translate_layout.addStretch(1)

        # 整体布局
        main_layout = QVBoxLayout()
        main_layout.addLayout(translator_layout)
        main_layout.addLayout(input_output_layout)
        main_layout.addLayout(translate_layout)
        self.setLayout(main_layout)

        # 信号槽连接
        self.translateButton.clicked.connect(self.translate_text)

        # 设置窗口属性
        self.setWindowFlags(Qt.WindowStaysOnTopHint)  # 窗口总在最高层
        self.setGeometry(300, 300, 800, 450)  # 设置窗口大小和位置

        self.th = Worker()
        # self.th.update_date.connect(self.show_date)
        self.th.prev_text.connect(self.handle_signal)
        self.th.start()

        self.show()

    def handle_signal(self, value):
        self.th.pre_value = value
        self.tmp = " ".join(value.split("\n"))
        self.tmp = self.tmp.replace('\r', "", self.tmp.count('\r'))
        self.inputTextEdit.setText(" ".join(self.tmp.split("\r")))
        # print([" ".join(self.tmp.split("\r"))])

    def translate_text(self):
        text = self.inputTextEdit.toPlainText()
        # 根据选择框调用不同的API进行翻译
        if self.translatorComboBox.currentText() == '百度翻译':
            # 调用百度翻译API进行翻译
            # print("百度")
            self.outputTextEdit.setText(
                self.baidu_api.translate(text, from_lang=self.config['from_lang'], to_lang=self.config['to_lang']))
        elif self.translatorComboBox.currentText() == '腾讯翻译':
            # 调用腾讯翻译API进行翻译
            self.outputTextEdit.setText(
                self.tencent_api.translate(text, from_lang=self.config['from_lang'], to_lang=self.config['to_lang']))
            # print("腾讯")


if __name__ == '__main__':
    app = QApplication(sys.argv)
    translator = Translator()
    sys.exit(app.exec_())

使用pyperclip监控剪切板:

为了在体验上有一定的优化,使用pyperclip库监控剪切板的变化,并自动读取最新的复制内容。

class Worker(QThread):
    prev_text = pyqtSignal(str)
    pre_value = pyperclip.paste()  # 初始化

    def run(self):
        while True:
            # 读取剪贴板内容
            curr_text = pyperclip.paste()
            # print(self.pre_value)
            if curr_text != self.pre_value:
                # print([curr_text])
                self.prev_text.emit(curr_text)
            # 每1秒检查一次剪贴板内容
            time.sleep(1)

并且因为存在while True,所以使用QThread,防止阻塞界面。

self.th = Worker()
# self.th.update_date.connect(self.show_date)
self.th.prev_text.connect(self.handle_signal)
self.th.start()

在config.json内填入相关配置:

同级目录下创建config.json,填入相关配置,包括目标语言,API的id和key,才能正常使用。

{
  "from_lang": "auto",
  "to_lang": "zh",
  "BaiduAPI": {
    "id": "xxxxxxxxxxxxxxxx",
    "key": "xxxxxxxxxxxxxxxx"
  },
  "TencentAPI": {
    "id": "xxxxxxxxxxxxxxxx",
    "key": "xxxxxxxxxxxxxxxx"
  }
}

 使用Pyinstaller打包

如果不想每次都执行python demo_config_json.py来运行,可以自己编写.bat脚本或者使用Pyinstaller进行打包。

详细的打包流程,大家可以去找相关博客,也可以使用如下配置文件:

# -*- mode: python ; coding: utf-8 -*-

block_cipher = None

# 所有需要打包的.py文件
file = [
        'demo_config_json.py',
        'Baidu_Text_transAPI.py',
        'Tencent_Text_transAPI.py'
        ]

a = Analysis(file,
             pathex=['D:\\Projects\\Python\\Test'],  # 项目绝对路径
             binaries=[],
             datas=[("icon.png", "."), ("config.json", ".")],
             hiddenimports=[],
             hookspath=[],
             runtime_hooks=[],
             excludes=[],
             win_no_prefer_redirects=False,
             win_private_assemblies=False,
             cipher=block_cipher,
             noarchive=False)
pyz = PYZ(a.pure, a.zipped_data,
             cipher=block_cipher)
exe = EXE(pyz,
          a.scripts,
          a.binaries,
          a.zipfiles,
          a.datas,
          [],
          name='Baicent',  # exe的名称
          debug=False,
          bootloader_ignore_signals=False,
          strip=False,
          upx=True,
          upx_exclude=[],
          runtime_tmpdir=None,
          console=False,  #console=True表示,打包后的可执行文件双击运行时屏幕会出现一个cmd窗口,不影响原程序运行,如不需要执行窗口,改成False即可
          icon='D:\\Projects\\Python\\Test\\favicon.ico') #程序图标的绝对路径

参考博客:python3_将多个.py文件打包成exe程序并添加图标_python打包带图标-CSDN博客

效果及完整项目代码

界面效果:

觉得界面简陋的同学也可以自行构建界面,反正核心就是调API,总体没啥技术难度

完整项目代码: 

gitee:项目代码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/164631.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

算法通关村第十一关-青铜挑战理解位运算的规则

大家好我是苏麟 , 今天聊聊位运算 . 位运算规则 计算机采用的是二进制,二进制包括两个数码:0,1。在计算机的底层,一切运算都是基于位运算实现的,所以研究清整位运算可以加深我们对很多基础原理的理解程度。 在算法方面&#xf…

Python基础:错误和异常

在Python中的错误可(至少)被分为两种:语法错误和 异常,均是指在程序中发生的问题和意外情况。Python提供了异常处理机制,使程序能够更容易地应对这些问题。 1. 语法错误(Syntax Error) 语法错误…

4种经典的限流算法

0、基础知识 1000毫秒内,允许2个请求,其他请求全部拒绝。 不拒绝就可能往db打请求,把db干爆~ interval 1000 rate 2; 一、固定窗口限流 固定窗口限流算法(Fixed Window Rate Limiting Algorithm)是…

三相异步电机动态数学模型及矢量控制仿真

文章目录 三相异步电机动态数学模型及矢量控制仿真1、异步电机三相方程2、坐标变换3、磁链3/2变换推导4、两相静止坐标系下的方程5、两相旋转坐标系下的方程6、以 ω-is-Ψr 为状态变量的状态方程7、矢量控制及 matlab 仿真 原文链接需要仿真的同学请关注【Qin的学习营地】 三相…

Node.js之fs文件系统模块

什么是fs文件系统模块?又如何使用呢?让我为大家介绍一下! fs 模块是 Node.js 官方提供的、用来操作文件的模块。它提供了一系列的方法和属性,用来满足用户对文件的操作需求 注意:如果要在JavaScript代码中&#xff0c…

OS 进程同步

基本概念 定义:把异步环境下的一组并发进程因直接制约而相互发送消息、相互合作、相互等待,使得各进程按一定的速度执行的过程,称为进程同步 协作进程:具有同步关系的一组并发进程 进程同步机制的主要任务:在执行次…

pm2在Windows环境中的使用

pm2 进程管理工具可以Windows操作系统上运行,当一台Windows电脑上需要运行多个进程时,或者运维时需要运行多个进程以提供服务时。可以使用pm2,而不再是使用脚本。 1. 使用PM2管理进程 1.1. 启动PM2项目 1.1.1. 直接启动项目 参数说明&…

Transformer ZOO

Natural Language Processing Transformer:Attention is all you need URL(46589)2017.6 提出Attention机制可以替代卷积框架。引入Position Encoding,用来为序列添加前后文关系。注意力机制中包含了全局信息自注意力机制在建模序列数据中的长期依赖关系方面表现出…

iOS_折叠展开 FoldTextView

1. 显示效果 Test1:直接使用: Test2:在 cell 里使用: 2. 使用 2.1 直接使用 // 1.1 init view private lazy var mooFoldTextView: MOOFoldTextView {let view MOOFoldTextView(frame: .zero)view.backgroundColor .cyanvie…

QGroundControl源码编译的三种方法

1.使用QtCreator编译: 下载qgroundcontrol源码 https://github.com/mavlink/qgroundcontrol.git 克隆 同步子模块 使用打开qgroundcontrol.pro 打开前要求先安装qt 5.15.2

嵌入式开发--赛普拉斯cypress的铁电存储器FM25CL64B

嵌入式开发–赛普拉斯cypress的铁电存储器FM25CL64B 简介 FM25CL64B是赛普拉斯cypress出品的一款铁电存储器,这种存储器最大的优势是可以像RAM一样随机存储,和按字节写入,也可以像ROM一样掉电仍然可以保存数据,是一种相当优秀的…

重命名com1.{d3e34b21-9d75-101a-8c3d-00aa001a1652}文件夹

今天在win10系统上,发现一个名称为: com1.{d3e34b21-9d75-101a-8c3d-00aa001a1652} 的文件夹,该文件夹很奇怪,既不能手动删除,也不能手动给文件夹重命名,如图(1)所示: E:\EncodeOne\hello\Thumbs.ms\com1.…

【神印王座】月夜大尺度诱惑,皓晨潜入月魔宫,枫秀降临男扮女装

Hello,小伙伴们,我是拾荒君。 为了能安全回到联盟,龙皓晨决定让月夜商队护送他们,这也是他们目前处境更快更安全回到人类境地的方法。于是,龙皓晨只身一人去寻找月夜,此次执行的任务完全超出龙皓晨的掌握之外&#xf…

中国电影票房排行数据爬取及分析可视化

大家好,我是带我去滑雪! 对中国电影票房排行数据的爬取和分析可视化具有多方面的用处:例如了解电影市场的历史趋势,包括不同类型电影的受欢迎程度、票房的季节性波动。识别观众对于不同类型电影的偏好,为电影制片方提供…

Nodejs中net模块多次Socket.setTimeout无法覆盖之前函数,导致叠加执行问题解决

Hi, I’m Shendi Nodejs中net模块多次Socket.setTimeout无法覆盖之前函数,导致叠加执行问题解决 问题描述 在 Nodejs 中,net 模块的 Socket 的 setTimeout 函数是设置超时时间,如果多次设置,超时时间会是最后一次的时间&#xff…

4、FFmpeg命令行操作10

音视频处理流程 先看两条命令 ffmpeg -i test_1920x1080.mp4 -acodec copy -vcodec libx264 -s 1280x720 test_1280x720.flv ffmpeg -i test_1920x1080.mp4 -acodec copy -vcodec libx265 -s 1280x720 test_1280x720.mkv ffmpeg音视频处理流程

038、语义分割

之——介绍与数据集 杂谈 语义分割,语义分割(Semantic Segmentation)方法-CSDN博客: 语义分割是计算机视觉领域的一项重要任务,旨在将图像中的每个像素分配到其对应的语义类别中。与物体检测或图像分类不同,语义分割不仅要识别图像…

Zookeeper实战案例(1)

前置知识: Zookeeper学习笔记(1)—— 基础知识-CSDN博客 Zookeeper学习笔记(2)—— Zookeeper API简单操作-CSDN博客 Zookeeper 服务器动态上下线监听案例 需求分析 某分布式系统中,主节点可以有多台&am…

CV计算机视觉每日开源代码Paper with code速览-2023.11.15

点击CV计算机视觉,关注更多CV干货 论文已打包,点击进入—>下载界面 点击加入—>CV计算机视觉交流群 1.【基础网络架构:CNN】PadChannel: Improving CNN Performance through Explicit Padding Encoding 论文地址:https:/…