PHPgettext用法

gettext程序在Linux/Unix世界中很常见,但一般人日常使用的机会不多。它用来为应用程序添加国际化支持。举个例子,如果一个程序中的字符串资源没有硬编码在程序源文件中,而是以一种语言包的文件存在的,那么就可以通过添加语言包文件来改变程序界面的语言。gettext就可以做这种事。

Windows下的PHP5中已经带有了gettext扩展。在php.ini文件中将“extension=php_gettext.dll”前面的分号去掉,重启Apache,如果一切正常的话,在phpinfo()的输出中应该会有gettext一节。下面有一个简单的“Hello World”的例子来看看如何用gettext来达到支持多语言的目的。

创建一个PHP文件test.php,内容如下:

<?php            putenv("LANG=zh_CN");            setlocale(LC_ALL, 'zh_CN');            bindtextdomain('test', './locale');            textdomain('test');            echo gettext('Hello World!');           ?>

开头两行代码设置语言环境为’zh_CN’,也就是简体中文。bindtextdomain设置域test的目录为当前目录下的locale目录。textdomain(text)告诉PHP解释器,gettext函数要去test域中去寻找替代字符串。

在浏览器中打开这个文件,可以看到结果为“Hello World”,只是原样输出而已,因为还没有制作中文语言包。要让浏览器输出中文而不改变源程序,需要准备两个文件,POMO文件。为了得到这两个文件,需要使用xgettextmsgfmt两个程序。Windows用户可以去GnuWin32下载GetText软件包,里面就有这两个程序。

接着建立相应的目录结构。在test.php的目录下建立“locale\zh_CN\LC_MESSAGES”这样的目录。目录名zh_CN一定要和代码中的语言名称zh_CN相同。然后在命令提示符下执行:
xgettext -d test test.php
-d test”表示domain为“test”,这会在当前目录下生成test.po这个文件。用文本编辑器打开它,做如下修改:


Content-Type: text/plain; charset=GB2312\n
Content-Transfer-Encoding: 8bit\n

#: test.php:11
msgid Hello World!
msgstr “你好,世界!”

即将charset设置为中文编码“GB2312”,将相应的msgid中的英文字符串翻译成中文填入到下面的msgstr中。接下来用msgfmt生成MO文件。MO是一个二进制格式的文件,gettext从它里面提取字符串资源。在命令提示符中执行以下命令可以从刚刚修改的PO文件得到MO文件:
msgfmt -o test.mo test.po

最后将test.potest.mo放在locale\zh_CN\LC_MESSAGES目录下,刷新浏览器,即可看到显示的是中文。

对于使用gettextPHP程序来说,gettext函数往往用的非常多。因此在PHP中可以使用“_”来代替“gettext”,所以gettext(Hello World!)也可以写成“_(Hello World!)”。