欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

PHP中使用gettext解决国际化问题的例子(i18n)

程序员文章站 2023-11-16 15:22:52
实现国际化的方式比较多,很多php framework都内置i18n支持,但大部分是基于php的数组实现的,这种方法并不推荐。目前最为流行也最通用的方法是gettext。...

实现国际化的方式比较多,很多php framework都内置i18n支持,但大部分是基于php的数组实现的,这种方法并不推荐。目前最为流行也最通用的方法是gettext。

gettext 用于系统的国际化(i18n)和本地化(l10n),可以在编译程序的时候使用本国语言支持(native language support(nls)),其可以使程序的输出使用用户设置的语言而不是英文. 关于gettext的更多资料请参见: 下面说说如何利用gettext在你的php程序中实现国际化。


一、检查环境需求 首先查看phpinfo(),确保你的php启用了gettext扩展。如果启用了gettext,在phpinfo页面中应该能看到以下信息:
PHP中使用gettext解决国际化问题的例子(i18n)

如果没有找到,请修改php.ini以启用该扩展

二、为你的项目新建locale文件夹 gettext涉及到两个文件,*.po是翻译源文件,里面储存了项目中所有待翻译的字符串和翻译后的结果;*.mo文件是po文件编译后二进制文件,真正读取翻译信息的时候是从mo文件中读取的,所以这个文件也是必不可少的。 gettext对目录要求比较死,你必须把国际化文件放在指定目录,大部分使用gettext不成功都是由于po文件和mo文件没有放对位置导致的,下面举例看一个典型项目目录树:

PHP中使用gettext解决国际化问题的例子(i18n)

三、初始化i18n环境 这个主要是在程序端进行简单的设置,下面给个简单的例子:

复制代码 代码如下:

< ?php
//定义要翻译的目标语言及po文件的编码
$locale = "zh_cn.utf8";
setlocale(lc_all, $locale);

//设置翻译文本域,下面的代码就会让程序去locale/zh_cn/lc_messages/default.mo去寻找翻译文件
bindtextdomain("default", dirname(__file__)."/locale");
textdomain("default");
?>

< !doctype html public "-//w3c//dtd xhtml 1.1//en" "http://www.w3.org/tr/xhtml11/dtd/xhtml11.dtd">
< ?php echo _("hello\n");; ?>



四、建立po文件档

到这一步方法就比较多了,当然可以手动建立,不过这样子一个最大的缺点就是你不知道项目中哪些字符串需要翻译,这里推荐下一个软件——poedit,windows平台和linux都是适用的。

选择文件->新建消息目录文档,填好一些必要信息,注意如果目标语言是中文的话,由于中文是双字节字符,所以最好在“复数形式”填上 “nplurals=2; plural=(n!=1);”(没有引号),如下图

PHP中使用gettext解决国际化问题的例子(i18n)

然后将项目所在文件夹加入到“路径”中,设置好翻译所用的关键字,poedit就会自动搜索项目中所有待翻译的字符串,生成po文件。翻译完成后选择“保存”,poedit会自动生成mo文件。以后每次项目中待翻译字符串有更新,只要打开poedit选择类目->从源更新,就好了 这样的思路不仅适用于php,其他语言都大同小异,前段时间做django一个项目的翻译,也仅仅是建立po文件更加方便了,其他步骤十分类似。大家举一反三就好了,尤其注意下目录结构,这个是最容易出现问题的地方。