【云原生】Docker搭建开源翻译组件Deepl使用详解

news2024/12/26 22:56:51

目录

一、前言

二、微服务项目使用翻译组件的场景

2.1 多语言用户界面

2.2 业务逻辑中的翻译需求

2.3 满足实时通信的要求

2.4 内容管理系统

2.5 个性化推荐系统

2.6 日志和监控

三、开源类翻译组件解决方案

3.1 国内翻译组件方案汇总

3.1.1 百度翻译

3.1.2 腾讯翻译​​​​​​​

3.1.3 阿里翻译(通用版)

3.1.4 华为翻译

3.1.5 小牛翻译

3.1.6 有道翻译

3.1.7 火山翻译

3.1.8 讯飞翻译

3.2 国外翻译组件方案汇总

3.2.1 谷歌翻译

3.2.2 DeepL翻译

3.2.3 微软翻译

3.2.4 亚马逊翻译

3.3 基于大模型或机器翻译框架

四、微服务项目中集成翻译组件

4.1 前置准备

4.2 对接小牛翻译

4.2.1 登录控制台

4.2.2 开通API翻译服务

4.2.3 代码集成与调用

4.3 补充说明

五、本地化部署翻译工具

5.1 DeeplX-Local 部署

5.1.1 项目说明

5.1.2 获取360 apikey

5.1.3 docker部署过程

5.1.4 效果测试

5.2 DeepLX Serverless 部署与使用

5.2.1 docker部署过程

5.2.2 效果测试

5.2.3 在Java代码中集成与使用

六、写在文末


一、前言

在微服务项目开发中,不少涉及需要进行中英互译,或不同语言进行翻译的场景,以满足实际业务的需求。随着国际化的潮流,很多互联网项目都在致力于打造并兼容多语言从而满足国际化的需求,从而增加了对翻译类技术的深度使用,本篇将介绍一些常用的解决方案,比如国内外开源组件,以及基于Docker本地化部署开源翻译组件。

二、微服务项目使用翻译组件的场景

在微服务架构的项目中,翻译类技术组件可以被用来解决多种语言环境下的需求,下面列举了一些通用的场景。

2.1 多语言用户界面

即操作界面需要支持国际化,具体来说:

  • 场景描述: 微服务应用需要支持多语言界面,为不同地区的用户提供本地化的体验。

  • 解决方案: 在前端微服务中集成翻译组件,根据用户的语言偏好动态加载翻译后的文本。

  • 实现方式: 前端微服务可以调用翻译服务的 API,获取当前语言环境下的 UI 文本。

2.2 业务逻辑中的翻译需求

程序代码中的特定场景下处理逻辑的需要,具体来说:

  • 场景描述: 在处理业务逻辑时,可能需要将某种语言的数据转换为另一种语言的数据。

  • 解决方案: 在处理业务逻辑的微服务中调用翻译服务,对数据进行翻译。

  • 实现方式: 业务逻辑微服务可以通过调用翻译服务的 REST API 来完成翻译操作。

2.3 满足实时通信的要求

一些实时通信的项目对此有最直接的需求:

  • 场景描述: 在提供实时通信功能(如聊天室、在线会议等)时,参与者可能来自不同国家和地区。

  • 解决方案: 在实时通信微服务中集成翻译组件,提供实时翻译功能。

  • 实现方式: 实时通信微服务可以监听消息队列中的消息,并调用翻译服务进行翻译后再转发给其他参与者。

2.4 内容管理系统

系统对各类内容发布的窗口需要支持多语言:

  • 场景描述: 内容管理系统需要支持多语言内容的创建、编辑和发布。

  • 解决方案: 在内容管理微服务中集成翻译组件,支持内容的多语言版本管理。

  • 实现方式: 内容管理微服务可以提供一个接口,允许用户提交内容翻译请求,并将翻译后的结果保存到数据库中。

2.5 个性化推荐系统

一些偏向推荐类的项目需要支持多语言的场景:

  • 场景描述: 个性化推荐系统需要根据用户的语言偏好推荐合适的内容。

  • 解决方案: 在推荐系统的微服务中集成翻译组件,对推荐内容进行翻译。

  • 实现方式: 推荐系统微服务可以根据用户的语言设置,调用翻译服务对推荐内容进行翻译。

2.6 日志和监控

对于操作日志展示类的系统,需要能切换不同的操作语言:

  • 场景描述: 在日志记录和监控系统中,可能需要记录用户的操作日志,包括他们使用的语言。

  • 解决方案: 在日志和监控系统的微服务中集成翻译组件,支持日志的多语言记录。

  • 实现方式: 日志记录微服务可以在记录用户操作日志时,调用翻译服务将日志内容翻译成适当的语言。

三、开源类翻译组件解决方案

经过多年的发展,市面上也涌现出了很多优秀的开源翻译组件可以在系统中直接集成使用,下面汇总了一些国内外的开源类翻译组件解决方案。

3.1 国内翻译组件方案汇总

3.1.1 百度翻译

百度翻译API接口免费翻译额度:

  • 标准版(5万字符免费/每月)、高级版(100万字符免费/每月-需个人认证,基本都能通过)、尊享版(200万字符免费/每月-需企业认证,门槛高);

  • 超出免费额度价格:49元/百万字符;

  • 官方介绍:百度翻译开放平台

3.1.2 腾讯翻译

翻译API是一种提供自动翻译功能的云计算服务,具体来说:

  • API接口免费翻译额度:500万字符免费/每月;

  • 超出免费额度价格:58元/百万字符,有字符资源包出售;

  • 官方介绍:机器翻译 计费概述-购买指南-文档中心-腾讯云

3.1.3 阿里翻译(通用版)

依托阿里巴巴自然语言处理技术和海量数据优势,致力于解决全场景语言障碍,多领域适用,可快速实现一种语言到另一种语言的自动翻译,覆盖全球214种语言。具体来说:

  • 阿里云翻译API接口免费翻译额度:100万字符免费/每月;

  • 超出免费额度价格:50元/百万字符,有字符资源包出售;

  • 官方介绍:机器翻译的付费模式及具体定价_机器翻译-阿里云帮助中心

3.1.4 华为翻译

机器翻译(Machine Translation)致力于为企业和个人提供不同语种间快速翻译能力,通过API调用即可实现源语言文本到目标语言文本的自动翻译,具体来说:

  • 华为翻译API接口免费翻译额度: 100万字符免费/每月;

  • 超出免费额度价格:50元/100万字符;

  • 官方介绍:机器翻译语言翻译翻译中心即时通讯视频字幕翻译解决方案-华为云

3.1.5 小牛翻译

通过HTTP协议提供400+语言的互译服务,将一段源语言文本转换成目标语言文本,可根据语言参数的不同实现多国语言之间的互译。具体来说:

  • 小牛翻译API接口免费翻译额度: 20万字符免费/每日(相当于于600万免费每月),新用户还可以领一次100万字符免费福利;

  • 超出免费额度价格:只按字符资源包出售(例如1000万字符包-1年-500元,5000万字符包-1年-2000元...);

  • 官方介绍:小牛翻译开放平台 - 机器翻译找小牛-纯文本翻译、小牛翻译开放平台 - XML翻译

3.1.6 有道翻译

网易有道旗下一站式人工智能服务提供商,为政府、企业和开发者提供稳定可靠的基础AI能力,具体来说:

  • 有道翻译API接口免费翻译额度:无,新用户一次性赠50元免费体验资金;

  • 超出免费额度价格:48元/百万字符,有字符资源包出售;

  • 官方介绍:有道翻译产品文档-自然语言翻译服务

3.1.7 火山翻译

火山翻译的机器翻译服务提供快速、稳定、安全的多语言翻译能力,支持包括文本、图像、音视频文件、实时语音流等场景的翻译,开发人员可以轻松地集成使用。凭借多年数据积累和技术创新,火山翻译的API服务于新闻、视频、游戏、直播、小说、办公、社交等领域,具备独特的优势。具体来说:

  • 火山翻译API接口免费翻译额度:200万字符免费/每月;

  • 超出免费额度价格:49元/百万字符;

  • 官方介绍:产品计费--机器翻译-火山引擎

3.1.8 讯飞翻译

基于讯飞自主研发的机器翻译引擎,支持多达70+个语言与中文互译。适用于翻译机、同声传译等场景,可提供公有云接口及私有化部署方案。具体来说:

  • 讯飞翻译API接口免费翻译额度:讯飞翻译普通版 - 200万字符免费包(1年内,该免费包仅能领一次),讯飞翻译niutrans版 - 200万字符免费包(90天内,该免费包仅能领一次);

  • 超出免费额度价格:只按字符资源包出售(例如100万字符包-1年-48元,2000万字符包-1年-900元...);

  • 官方介绍:机器翻译-讯飞开放平台、机器翻译 niutrans - 语音扩展 - 讯飞开放平台

3.2 国外翻译组件方案汇总

相比国内的翻译组件,国外的几种翻译组件具有更长的历史,下面分别做说明。

3.2.1 谷歌翻译

谷歌翻译(Google Translate)是由谷歌公司开发的一款在线翻译服务,旨在帮助用户在不同语言之间进行文字翻译,其特点来说:

  • 广泛的语言支持

    • 谷歌翻译支持超过 100 种语言的互译,包括常见的英语、汉语、西班牙语、法语、德语等,以及一些较为少见的语言。

  • 实时翻译

    • 提供实时翻译功能,用户可以在输入框中键入文字,系统会自动识别语言并进行翻译。

    • 实时语音翻译功能,支持语音输入及输出。

  • 图片翻译

    • 支持通过摄像头拍摄或上传图片,识别图片中的文字并进行翻译。这一功能对于旅游、阅读外文菜单等场合非常有用。

  • 离线翻译

    • 用户可以下载离线语言包,在没有网络连接的情况下也能进行翻译。

  • API 接口

    • 提供了 Google Cloud Translation API,允许开发者将谷歌翻译的功能集成到自己的应用程序中。

翻译包说明:

  • Google翻译API接口免费翻译额度: 50万字符免费/每月,新用户赠300美元(90天内有效);

  • 超出免费额度价格:20美元(约140元)/百万字符;

  • 官方介绍:https://cloud.google.com/translate/?hl=zh-cn

3.2.2 DeepL翻译

DeepL 是一款高质量的在线翻译服务,以其出色的翻译质量和自然流畅的翻译效果而闻名。与谷歌翻译相比,DeepL 在某些方面表现更为出色,特别是在处理欧洲语言方面。以下是关于 DeepL 翻译的一些详细介绍:

  • 高质量翻译

    • DeepL 使用先进的神经网络机器翻译技术,能够生成接近人工翻译的质量。它特别擅长处理复杂的句子结构和上下文相关的翻译。

  • 广泛的语言支持

    • DeepL 支持多种语言,包括但不限于英语、德语、法语、西班牙语、意大利语等等。

  • 实时翻译

    • DeepL 提供实时翻译功能,用户可以在输入框中键入文字,系统会自动识别语言并进行翻译。

  • 文档翻译

    • 用户可以直接上传文档(如 Word、PDF、PPT 等),DeepL 会对其进行翻译并保持原文档格式不变。

  • API 接口

    • 提供了 DeepL API,允许开发者将 DeepL 的翻译功能集成到自己的应用程序或网站中。API 支持多种编程语言,包括 Python、Java、C# 等。

  • 用户界面友好

    • DeepL 的网页版和移动应用界面简洁易用,支持拖放文件、文本高亮等功能,方便用户进行翻译。

  • 个性化翻译记忆库

    • DeepL Pro 版本允许用户创建自己的翻译记忆库,保存常用的翻译内容,以便在未来重复使用。

翻译包说明:

  • DeepL翻译API接口免费翻译额度:50万字符免费/每月(API Free版本,超出50万后无法使用,需使用API Pro版本);

  • 超出免费额度价格:25美元(约180元)/百万字符(Pro版本才可以使用,每月固定5.49美元套餐费,例如新加坡地区),申请开通困难可以尝试某宝;

  • 官方介绍:DeepL翻译API|机器翻译技术

3.2.3 微软翻译

微软翻译(Microsoft Translator)是由微软公司提供的一项在线翻译服务,旨在帮助用户在多种语言之间进行文本翻译。其主要特点如下:

  • 广泛的语言支持

    • 微软翻译支持超过 60 种语言的互译,包括常见的英语、汉语、西班牙语、法语、德语等,以及一些较为少见的语言,如阿塞拜疆语、哈萨克语等。

  • 实时翻译

    • 提供实时翻译功能,用户可以在输入框中键入文字,系统会自动识别语言并进行翻译。

    • 实时语音翻译功能,支持语音输入及输出。

  • 图片翻译

    • 支持通过摄像头拍摄或上传图片,识别图片中的文字并进行翻译。这一功能对于旅游、阅读外文菜单等场合非常有用。

  • 离线翻译

    • 用户可以下载离线语言包,在没有网络连接的情况下也能进行翻译。

  • 文档翻译

    • 支持上传文档(如 Word、Excel、PowerPoint、PDF 等),并将文档内容翻译成所需的目标语言。

  • API 接口

    • 提供了 Azure Translator Text API,允许开发者将微软翻译的功能集成到自己的应用程序中。API 支持多种编程语言,包括 C#、Java、Python、Node.js 等。

  • 个性化设置

    • 用户可以根据需要选择不同的发音风格和翻译风格,以适应不同的场景需求。

  • 集成工具

    • 微软翻译可以与 Office 等微软产品无缝集成,提供更便捷的翻译体验。

翻译包说明:

  • 微软翻译API接口免费翻译额度:200万字符免费/每月(新用户前12个月才有);

  • 超出免费额度价格:10美元(约71元)/百万字符;

  • 官方介绍:Translator - 翻译服务型软件 | Microsoft Azure

3.2.4 亚马逊翻译

亚马逊翻译(Amazon Translate)是亚马逊云服务(AWS)提供的一项机器翻译服务,旨在为企业和个人用户提供高质量的文本翻译。其主要特点如下:

  • 广泛的语言支持

    • 亚马逊翻译支持多种语言的互译,包括常见的英语、汉语、西班牙语、法语、德语、意大利语、日语、韩语、葡萄牙语等。具体支持的语言列表会随着服务的发展而更新。

  • 高质量翻译

    • 亚马逊翻译采用神经网络机器翻译(Neural Machine Translation, NMT)技术,能够生成自然流畅的翻译结果,尤其适合处理长句和复杂的语法结构。

  • 实时翻译

    • 提供实时翻译功能,用户可以在输入框中键入文字,系统会自动识别语言并进行翻译。

  • 文档翻译

    • 支持上传文档(如 PDF、Word、Excel、PowerPoint 等),并将文档内容翻译成所需的目标语言。

  • API 接口

    • 提供了 Amazon Translate API,允许开发者将翻译功能集成到自己的应用程序或网站中。API 支持多种编程语言,包括 Java、Python、Node.js 等。

  • 高度可扩展性

    • 作为 AWS 的一部分,亚马逊翻译具有高度的可扩展性,可以轻松处理大量翻译请求,适合大规模的企业级应用。

  • 集成与自动化

    • 可以与其他 AWS 服务集成,如 Amazon S3、Amazon Lex、Amazon Polly 等,提供更加丰富的功能组合。

翻译包说明:

  • Amazon翻译API接口免费翻译额度:200万字符免费/每月(新用户前12个月才有);

  • 超出免费额度价格:15美元(约107元)/百万字符;

  • 官方介绍:Amazon Translate 神经网络机器翻译_自然语言处理-AWS云服务

3.3 基于大模型或机器翻译框架

上述提供的国内外开源翻译组件你仍然觉得对接麻烦,或者担心存在一定的数据安全风险,也可以考虑基于开源的大模型,或一些成熟的机器学习框架进行本地化部署,通过一定的训练之后用于提供翻译服务。下面提供几种可用于本地部署的翻译类机器学习框架:

  • OpenNMT

    • 描述: OpenNMT 是一个开源的神经网络机器翻译框架,支持多种语言对。

    • 用途: 适合有机器学习经验的开发者,需要自己训练模型。

    • 集成方式: 通过 REST API 或者部署为微服务后调用。

  • Marian NMT

    • 描述: Marian 是一个快速的神经机器翻译框架,支持 GPU 和 CPU。

    • 用途: 同样适合有机器学习经验的开发者,需要自行训练模型。

    • 集成方式: 可以通过 REST API 调用。

  • Apertium

    • 描述: Apertium 是一个轻量级的开源机器翻译平台,专注于资源匮乏的语言对。

    • 用途: 提供了一些预训练的模型,包括一些不太常见的语言对。

    • 集成方式: 可以通过 HTTP API 调用,也可以直接部署本地服务。

四、微服务项目中集成翻译组件

接下来在演示如何在springboot项目中集成常用的翻译组件进行使用。

4.1 前置准备

提前搭建一个springboot工程,导入下面基础依赖

		<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <scope>provided</scope>
        </dependency>

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>2.0.35</version>
        </dependency>

        <dependency>
            <groupId>com.squareup.okhttp3</groupId>
            <artifactId>okhttp</artifactId>
            <version>4.12.0</version>
        </dependency>

4.2 对接小牛翻译

官方主页:小牛翻译开放平台 - 机器翻译找小牛

4.2.1 登录控制台

登录官网之后注册一个账号,然后从控制台获取apikey的信息,以及API层面的对接文档,如下:

4.2.2 开通API翻译服务

点击开通服务

开通之后,会产生 api-key和appid,请妥善保管

点击查看开发文档:小牛翻译开放平台 - 机器翻译找小牛,即可看到如下详细的文档对接说明。

4.2.3 代码集成与调用

以文本翻译API为例进行操作,你也可以翻到每个API的最后,里面提供了对接API的代码示例

完整的代码如下:

package com.congge.translate;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.nio.charset.StandardCharsets;

public class NiuTransAPIExample {

    public static void main(String[] args) {
        String requestUrl = "http://api.niutrans.com/NiuTransServer/translation";
        String apiKey = "你的apikey";
        String textToTranslate = "你好,世界!";
        String sourceLang = "zh";
        String targetLang = "en";
        try {
            URL url = new URL(requestUrl);
            HttpURLConnection connection = (HttpURLConnection) url.openConnection();
            // 设置请求类型为 POST
            connection.setRequestMethod("GET");
            // 添加请求头
            connection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
            // 设置允许输出
            connection.setDoOutput(true);
            // 构造请求参数
            String requestBody = "from=" + sourceLang + "&to=" + targetLang + "&src_text=" + textToTranslate +"&apikey="+apiKey;
            // 写入请求数据
            try (OutputStream os = connection.getOutputStream()) {
                byte[] input = requestBody.getBytes(StandardCharsets.UTF_8);
                os.write(input, 0, input.length);
            }
            // 获取响应码
            int responseCode = connection.getResponseCode();
            System.out.println("Response Code : " + responseCode);
            // 读取响应数据
            try (BufferedReader br = new BufferedReader(
                    new InputStreamReader(connection.getInputStream(), StandardCharsets.UTF_8))) {
                StringBuilder response = new StringBuilder();
                String responseLine;
                while ((responseLine = br.readLine()) != null) {
                    response.append(responseLine.trim());
                }
                System.out.println("Response Body: " + response.toString());
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

运行上面的代码,控制台可以看到能够正常将中文翻译成英文

4.3 补充说明

上面演示了其中一种市面上的开源翻译组件的对接过程,像腾讯云、阿里云、亚马逊等翻译组件的对接过程也是大同小异,有兴趣的同学可以用类似的方式对接并在程序中集成即可,要注意的是,针对新注册的账户,不同的厂商提供了一定的免费额度以供使用,但是如果你的实际业务中翻译量很大,免费的额度不够用,建议还是开通付费包,避免使用过程中因为额度问题造成了业务上的影响。

五、本地化部署翻译工具

如果上面的方式都不能满足你的需求,最后再提供一种可行的解决方案,即本地私有化部署开源的翻译工具进行使用,当然,这种方式根据你的场景不同,在部署的成本上也不太一样,比如你只是做简单的开发测试,跟你想大规模使用翻译,在组件的选择上也会存在差异,下面以deepl的一个开源工具插件为例,进行本地化部署和对接使用的操作演示。

5.1 DeeplX-Local 部署

项目地址:GitCode - 全球开发者的开源社区,开源代码托管平台

5.1.1 项目说明

ycvk/deeplx-local 是一个基于 DeepL 翻译引擎的本地部署解决方案,它使开发者和用户能够无需外部 API 密钥,在本地环境中运行高效、低延迟的翻译服务。该项目设计用于支持大规模文本的翻译,并提供了智能的文本拆分与并行处理能力,确保了翻译任务的流畅进行。它支持一键启动并通过 Docker 化简化了部署流程,非常适合希望拥有私有翻译服务的个人或企业。

5.1.2 获取360 apikey

使用docker部署deeplx-local时,为了确保能够正常使用,还需要在docker运行的参数里面添加360_api_key,否则无法正常运行,通过git项目中的链接跳转到quake.360进行一下注册,然后在自己的控制台上即可获取这个apikey

需要注意的是,这种方式是有次数限制的

5.1.3 docker部署过程

对于希望通过 Docker 快速部署的用户,只需执行以下命令:

docker run -itd --name deeplx-local -p 8081:62155 -e 360_api_key="你的360apikey" neccen/deeplx-local:latest

这将启动容器并将服务暴露在本地的 8080 端口,翻译接口可通过 http://localhost:8080/translate 访问。如需自定义路由,可以添加环境变量 -e route=你的路由名称,例如:

docker run -itd --name deeplx-local -p 8081:62155 -e route=my-translate -e 360_api_key="你的360apikey" neccen/deeplx-local:latest

5.1.4 效果测试

部署成功后,使用下面的命令做一下测试

curl -X POST http://localhost:8081/translate \
     -H 'Content-Type: application/json' \
     --data '{"text":"你好,世界!","targetLang":"en"}'

可以看到能够正常进行翻译

5.2 DeepLX Serverless 部署与使用

这是一个基于 DeepL翻译API 的无服务器函数部署项目,旨在提供一个可直接对接的免费翻译解决方案,很适合需要在无服务器环境中集成DeepL翻译服务的开发者使用。

与原项目DeepLX的区别在于利用了无服务器函数(边缘函数)请求IP不固定的特性,有效避免了Error 429请求太频繁的报错;

虽然因此不会立马被暂时封禁,但也请不要滥用!目前我部署在vercel上会有流量限制,如果您有大量内容需要翻译,请购买DeepL的付费版,当前项目使用的free接口会受到DeepL政策限制由于目前项目未对pro接口进行适配,所以现在还只能使用free接口,不过在将来会完善

5.2.1 docker部署过程

运行下面的命令启动容器

docker run -d -p 8085:6119 ghcr.io/guobao2333/deeplx-serverless

5.2.2 效果测试

使用下面的命令进行测试

curl --location --request POST 'http://localhost:8085/translate' --header 'Content-Type: application/json' --data '{"text": "你好,世界!", "source_lang": "zh", "target_lang": "en"}'

也能正确得到翻译结果

5.2.3 在Java代码中集成与使用

基于上述搭建的本地deepl的翻译服务,下面通过代码调用测试一下,下面是调用的完整代码

package com.congge.translate;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.nio.charset.StandardCharsets;

public class DeepLLocalTest {

    public static void main(String[] args) {
        String requestUrl = "http://部署的IP:8085/translate";
        String requestJson = "{\"text\": \"Hello , World!\", \"source_lang\": \"en\", \"target_lang\": \"zh\"}";
        try {
            URL url = new URL(requestUrl);
            HttpURLConnection connection = (HttpURLConnection) url.openConnection();
            // 设置请求类型为 POST
            connection.setRequestMethod("POST");
            // 添加请求头 Content-Type
            connection.setRequestProperty("Content-Type", "application/json");
            // 设置允许输出
            connection.setDoOutput(true);
            // 写入请求数据
            try (OutputStream os = connection.getOutputStream()) {
                byte[] input = requestJson.getBytes(StandardCharsets.UTF_8);
                os.write(input, 0, input.length);
            }
            // 获取响应码
            int responseCode = connection.getResponseCode();
            System.out.println("Response Code : " + responseCode);
            // 读取响应数据
            try (BufferedReader br = new BufferedReader(
                    new InputStreamReader(connection.getInputStream(), StandardCharsets.UTF_8))) {
                StringBuilder response = new StringBuilder();
                String responseLine;
                while ((responseLine = br.readLine()) != null) {
                    response.append(responseLine.trim());
                }
                System.out.println("Response Body: " + response.toString());
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

}

运行上面的代码,通过控制台可以看到已经得到正确的翻译结果

六、写在文末

本文通过较大的篇幅详细结束了常用的翻译组件的使用,最后以deepl为例进行本地化部署,并结合代码进行演示操作,希望对看到的同学有用,本篇到此结束,感谢观看。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

DFA算法实现敏感词过滤

DFA算法实现敏感词过滤 需求&#xff1a;检测一段文本中是否含有敏感词。 比如检测一段文本中是否含有&#xff1a;“滚蛋”&#xff0c;“滚蛋吧你”&#xff0c;“有病”&#xff0c; 可使用的方法有&#xff1a; 遍历敏感词&#xff0c;判断文本中是否含有这个敏感词。 …

如何在Linux系统中使用Netcat进行网络调试

文章目录 Netcat简介安装Netcat在Debian/Ubuntu系统中安装在CentOS/RHEL系统中安装 Netcat基本命令Netcat基本用法示例1&#xff1a;监听端口示例2&#xff1a;连接到远程主机 Netcat选项-l选项-p选项-v选项 Netcat模式监听模式连接模式 Netcat排除和包含排除端口包含端口 Netc…

【ClickHouse 探秘】你知道 ClickHouse MergeTree 引擎吗?

&#x1f449;博主介绍&#xff1a; 博主从事应用安全和大数据领域&#xff0c;有8年研发经验&#xff0c;5年面试官经验&#xff0c;Java技术专家&#xff0c;WEB架构师&#xff0c;阿里云专家博主&#xff0c;华为云云享专家&#xff0c;51CTO 专家博主 ⛪️ 个人社区&#x…

推荐一款高效的内存清理工具:MemoryCleaner

MemoryCleaner是一款高效的内存清理工具&#xff0c;旨在优化您的计算机性能。它利用Windows内置的多种功能&#xff0c;能够在不影响系统运行的情况下&#xff0c;自动释放内存。用户可以通过系统托盘直接访问MemoryCleaner的功能&#xff0c;无需打开程序&#xff0c;使得内存…

MySQL分区表(二)

说明&#xff1a;之前有写过一篇博客&#xff0c;介绍MySQL如何建立分区表&#xff0c;本文介绍如何建立子分区表。子分区&#xff0c;就是在原来分区的基础上&#xff0c;再嵌套一个分区。 例如&#xff0c;按照记录的创建时间分区&#xff0c;在此基础上&#xff0c;再按照租…

ssm043基于JavaEE的龙腾公司员工信息管理系统的设计与实现+jsp(论文+源码)_kaic

毕 业 设 计&#xff08;论 文&#xff09; 题目&#xff1a;龙腾公司员工信息管理系统设计与实现 摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本龙腾公司…

使用 PyCharm 构建 FastAPI 项目:零基础入门 Web API 开发

使用 PyCharm 构建 FastAPI 项目&#xff1a;零基础入门 Web API 开发 本文提供了一份完整的 FastAPI 入门指南&#xff0c;涵盖从环境搭建、依赖安装到创建并运行一个简单的 FastAPI 应用的各个步骤。通过 FastAPI 和 Uvicorn&#xff0c;开发者可以快速构建现代化的 Web API…

<项目代码>YOLOv8 夜间车辆识别<目标检测>

YOLOv8是一种单阶段&#xff08;one-stage&#xff09;检测算法&#xff0c;它将目标检测问题转化为一个回归问题&#xff0c;能够在一次前向传播过程中同时完成目标的分类和定位任务。相较于两阶段检测算法&#xff08;如Faster R-CNN&#xff09;&#xff0c;YOLOv8具有更高的…

centos7.X zabbix监控参数以及邮件报警和钉钉报警

1&#xff1a;zabbix安装 1.1 zabbix 环境要求 硬件配置: 2个CPU核心, 4G 内存, 50G 硬盘&#xff08;最低&#xff09; 操作系统: Linux centos7.2 x86_64 Python 2.7.x Mariadb Server ≥ 5.5.56 httpd-2.4.6-93.el7.centos.x86_64 PHP 5.4.161.2 zabbix安装版本 [rootnod…

类(4)

1.拷贝构造函数 我们在创建对象得的时候&#xff0c;可否创造一个与已存在对象一摸一样的对象呢&#xff1f; 拷贝构造函数&#xff1a;只有单个形参&#xff0c;该形参是对本类类型对象的引用&#xff08;一般常用const修饰&#xff09; 用在已存在的类类型对象创建新对象时…

‌【元素周期表】氢

化学式&#xff1a;H₂ 外观&#xff1a;无色透明 分子量&#xff1a;2.01588 吸入少量氢气对人体没有危害&#xff0c;甚至还可能对人体有益。但是不能吸入大量氢气&#xff0c;否则可能会对身体造成影响。 氢在生活中的主要用途包括以下几个方面‌&#xff1a; ‌医疗保健…

【06】A-Maven项目SVN设置忽略文件

做Web项目开发时&#xff0c;运用的是Maven管理工具对项目进行管理&#xff0c;在项目构建的过程中自动生成了很多不需要SVN进行管理的文件&#xff0c;SVN在对源码进行版本管理时&#xff0c;需要将其忽略&#xff0c;本文给出了具体解决方案。 SVN设置忽略Maven项目中自动生成…

【Windows】X-DOC:无需NAS使用Windows也能安装Jellyfin玩私人影音媒体平台

【Windows】X-DOC&#xff1a;无需NAS使用Windows也能安装Jellyfin玩私人影音媒体平台 1、前言2、Jellyfin服务搭建2.1 Jellyfin简介2.2 Jellyfin下载2.3 Jellyfin安装2.4 Jellyfin设置2.5 Jellyfin使用 3、终端访问3.1 浏览器访问 4、内网穿透 1、前言 下载收藏高清电影、电视…

海的记忆篇章:海滨学院班级回忆录项目

摘要 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;管理信息系统的实施在技术上已逐步成熟。本文介绍了海滨学院班级回忆录的开发全过程。通过分析海滨学院班级回忆录管理的不足&#xff0c;创建了一个计算机管理海滨学院班级回忆录的方案。文章介绍了海滨学院班级回…

Unity 使用Netcode实现用户登录和登出

Unity之NetCode for GameObjets 基本使用 说明思路相关API代码实现Tips 说明 最近项目需要联机&#xff0c;项目方案选用Unity提供的NetCode for GameObjets&#xff08;以下简称NGO&#xff09;&#xff0c;踩了不少坑&#xff0c;本文不介绍基础使用&#xff0c;围绕双端&…

C++(类和对象-运算符重载)

运算符重载概念&#xff1a; 对已有的运算符重新进行定义&#xff0c;赋予其另一种功能&#xff0c;以适应不同的数据类型 运算符重载的同时也可以发生函数重载 1.加号运算符重载 1.1加号运算符重载的本质 1.2运算符重载也可以发生函数重载 总结1&#xff1a;对于内置的数据类型…

Flink CDC 同步 Mysql 数据

文章目录 一、Flink CDC、Flink、CDC各有啥关系1.1 概述1.2 和 jdbc Connectors 对比 二、使用2.1 Mysql 打开 bin-log 功能2.2 在 Mysql 中建库建表准备2.3 遇到的坑2.4 测试 三、番外 一、Flink CDC、Flink、CDC各有啥关系 Flink&#xff1a;流式计算框架&#xff0c;不包含 …

Sigrity Power SI VR noise Metrics check模式如何进行电源噪声耦合分析操作指导

SSigrity Power SI VR noise Metrics check模式如何进行电源噪声耦合分析操作指导 Sigrity Power SI的VR noise Metrics check模式本质上是用来评估和观测器件的电源网络的耦合对于信号的影响,输出S参数以及列出具体的贡献值。 以下图为例

Vue computed watch

computed watch watch current prev

恋爱脑学Rust之智能指针Rc,RefCell和Weak指针

小明和小丽为了维系彼此的关系&#xff0c;一起探索了智能指针的奥秘。通过 Rc、RefCell 和 Weak 的帮助&#xff0c;他们得以克服情感中遇到的种种困境。 第一章&#xff1a;Rc 智能指针的共生 小明和小丽搬进了一个共同的小屋&#xff0c;他们彼此相爱&#xff0c;决定共用…