0

0

Go 应用国际化 (I18n) 实践指南:基于 go-gettext

碧海醫心

碧海醫心

发布时间:2025-09-26 17:14:01

|

654人浏览过

|

来源于php中文网

原创

go 应用国际化 (i18n) 实践指南:基于 go-gettext

本文档旨在为 Go 语言开发者提供一套基于 go-gettext 库的国际化 (I18n) 解决方案,适用于 Web 应用的本地化。内容涵盖环境配置、代码实现、模板生成、翻译以及部署,通过具体示例,指导开发者完成从零开始的 Go 应用国际化改造。

1. 环境准备

首先,确保你的 Go 项目已经初始化。然后,你需要克隆 go-gettext 库到你的项目中。假设你的项目目录结构如下:

~appname/
 |~app/
 | `-app.go
 |+github.com/
 `-app.yaml

执行以下命令克隆 go-gettext:

$ cd appname
$ git clone git://github.com/samuel/go-gettext.git github.com/samuel/go-gettext

2. 代码实现

在你的 Go 代码中使用 go-gettext 库进行国际化。 以下是一个简单的示例:

package app

import (
    "fmt"
    "log"
    "net/http"

    "github.com/samuel/go-gettext"
)

func init() {
    http.HandleFunc("/", home)
}

func home(w http.ResponseWriter, r *http.Request) {
    d, err := gettext.NewDomain("appname", "locale")
    if err != nil {
        log.Fatal("Failed at NewDomain.")
    }

    cat := d.GetCatalog("fr_FR")
    if cat == gettext.NullCatalog {
        log.Fatal("Failed at GetCatalog.")
    }

    fmt.Fprintf(w, cat.GetText("Yes."))
}

说明:

  • gettext.NewDomain("appname", "locale") 创建一个新的 Gettext 域,appname 是你的应用名称,locale 是存放本地化文件的目录。
  • d.GetCatalog("fr_FR") 获取法语 (法国) 的 catalog。
  • cat.GetText("Yes.") 获取 "Yes." 对应的法语翻译。

注意: go-gettext 库不支持 _("String to be translated") 这种简写形式,因为下划线在 Go 语言中有特殊含义。你需要使用 GetText 这样的函数名来包裹需要翻译的字符串。

3. 生成模板文件 (.pot)

使用 xgettext 工具从 Go 代码中提取需要翻译的字符串。

$ xgettext -d appname -kGetText -s -o appname.pot app/app.go

参数说明:

  • -d appname: 指定域名为 appname。
  • -kGetText: 指定需要提取的函数名为 GetText (大小写敏感)。
  • -s: 添加源代码位置信息到 .pot 文件中。
  • -o appname.pot: 指定输出文件为 appname.pot。

重要: -kGetText 参数是必需的,否则 xgettext 将无法识别 GetText 函数调用,.pot 文件将为空。

4. 创建和编辑翻译文件 (.po)

创建本地化目录和 .po 文件。

GPT Detector
GPT Detector

在线检查文本是否由GPT-3或ChatGPT生成

下载
$ mkdir -p locale/fr_FR/LC_MESSAGES
$ msginit -l fr_FR -o french.po -i appname.pot

参数说明:

  • -l fr_FR: 指定语言为法语 (法国)。
  • -o french.po: 指定输出文件为 french.po。
  • -i appname.pot: 指定输入文件为 appname.pot。

编辑 french.po 文件,添加翻译:

# Appname l10n
# Copyright (C) 2023 Your Name
# This file is distributed under the same license as the appname package.
# Your Name <>, 2023.
#
msgid ""
msgstr ""
"Project-Id-Version: appname v0.1\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2023-10-27 10:00+0000\n"
"PO-Revision-Date: 2023-10-27 10:10+0000\n"
"Last-Translator: Your Name <>\n"
"Language-Team: French\n"
"Language: fr\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
"Plural-Forms: nplurals=2; plural=(n > 1);\n"

#: app/app.go:15
msgid "Yes."
msgstr "Oui."

将 msgid "Yes." 对应的 msgstr 修改为法语翻译 "Oui."。

5. 生成二进制翻译文件 (.mo)

使用 msgfmt 工具将 .po 文件编译成 .mo 文件。

$ msgfmt -c -v -o locale/fr_FR/LC_MESSAGES/appname.mo french.po

参数说明:

  • -c: 检查翻译文件语法。
  • -v: 显示详细信息。
  • -o locale/fr_FR/LC_MESSAGES/appname.mo: 指定输出文件为 appname.mo。

6. 部署

最终的目录结构应该如下所示:

~appname/
 |~app/
 | `-app.go
 |~github.com/
 | `~samuel/
 |   `~go-gettext/
 |     +locale/
 |     |-catalog.go
 |     |-domain.go
 |     `-mo.go
 |~locale/
 | `~fr_FR/
 |   `LC_MESSAGES/
 |    `-appname.mo
 `-app.yaml

将 appname 部署到你的环境中。访问应用时,如果一切配置正确,你应该看到 "Oui."。

注意事项:

  • go-gettext 库的 locale 目录(在 github.com/samuel/go-gettext 下)包含测试数据,可以安全地从部署包中删除。
  • 确保服务器或应用环境能够正确识别和处理语言区域设置。

总结

通过以上步骤,你已经成功地使用 go-gettext 库为你的 Go 应用实现了国际化。 这只是一个简单的示例,你可以根据你的实际需求进行扩展,例如支持更多的语言、使用更复杂的翻译逻辑等。记住,国际化是一个持续的过程,需要不断地更新和维护翻译文件,以确保你的应用能够为不同语言的用户提供最佳的体验。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

338

2023.08.02

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

258

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1489

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

621

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

551

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

566

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

166

2025.07.29

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

38

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.9万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号