Django国际化依赖于GNU gettext工具集,所以在实现国际化之前需要先装gettext. sudo apt-get install gettext
可以通过在python交互模式下测试一下有没有安装成功 import django
from django.utils.translation import ugettext
Django实现翻译需要在python代码和模板中添加钩子(翻译字符串) 如: python代码中: ugettext(“test”) django模板中: {% trans “test” %} 当然,Django国际化不仅仅这么简单,还有ungettext, gettext_lazy, blocktrans等等,这里只是介绍实现国际化需要的操作. 1.创建一个项目
2.Django国际化的配置需要在settings文件中添加以下几个东西: USE_I18N = True
在middleware中添加 'django.middleware.locale.LocaleMiddleware',
当然,这个middleware不是随便添加的,需要添加在sessionMiddleware之后,CommonMiddleware之前,如果使用的CacheMiddleware则放在CacheMiddleware之后. 3.创建一个APP python manage.py startapp internation
或者使用 django-admin.py startapp internation
然后在settings的app中添加internation 4.创建view cd internation
创建view函数 from django.utils.translation import ugettext as _
from django.shortcuts import render_to_respoonse
def test_trans(request):
return render_to_response("hello.html", {"hi": _("hi")})
5.配置url 在urls.py中添加 from internation.views import test_trans
url(r'^hello/$', test_trans),
6.在internation中添加templates, 创建hello.html mkdir templates
touch hello.html
记住要在hello.html中添加{% load i18n %}(写在最开头) 然后编写简单代码 {% load i18n %} <!DOCTYPE html> <html> <head> <title>welcome</title> </head> <body> <span>{{ hi }}</span> </body> </html>
7.生成翻译文件 在app下创建locale文件夹,因为在运行时,Django构建一个内存中的文字-翻译目录,其搜索加载编译后的.mo文件的顺序是: 优先搜索settings文件中LOCALE_PATHS配置的路径, 其次搜索各个app下有没有locale 最后,django/conf/locale中提供的Django提供的基本翻译用作后备. 其实,locale因为主要作用于整个项目,而不是某个app,所以推荐创建在最外面,和manage.py在同一个根目录下 然后在settings.py中添加: import os PROJECT_ROOT = os.path.abspath(os.path.dirname(__file__)) LOCALE_PATHS = ( os.path.join(PROJECT_ROOT, 'locale/'), )
接着使用命令: python manage.py makemessages -l en_US
python manage.py makemessages -l zh_CN
此时locale目录结构应该是: –locale –en_US –LC_MESSAGES –django.po –zh_CN –LC_MESSAGES –django.po 编辑en_US下的django.po msgid "hi"
msgstr "hello"
zh_CN下的django.po msgid "hi"
msgstr "你好"
调用命令python manage.py compilemessages 将会生成对应的django.mo文件. 因为我把LOCALE_PAHTS设置成与settings.py在同一目录下的缘故,需要将编译好的locale移到translation中. 8.测试运行 python manage.py runserver 8000 打开浏览器输入: http://127.0.0.1:8000/hello 即可看到"你好"或者"hello" 主要看浏览器的当前语言设置,可以在设置中更改当前语言. 9.更高级的使用方法 很多网站上都提供按钮来切换语言,一般都是中英文切换,这里就用最简单的按钮切换中英文. 只需要在之前的代码上稍作修改. 首先需要在settings.py中添加 LANGUAGES = ( ('en', 'English'), ('zh-CN', 'Chinese'), )
表示两种语言切换. 然后在urls.py中添加 (r'^i18n/', include('django.conf.urls.i18n')),
接着在hello.html修改为 ... <body> <form action="/i18n/setlang/" method="post" id="myform"> <input type="hidden" name="next" value="{{ to_url }}" /> {% for language in LANGUAGES %} {% ifnotequal LANGUAGE_CODE language.0 %} <input type="hidden" name="language" value="{{ language.0 }}"/> {% endifnotequal %} {% endfor %} </form> <span>{{ hi }}</span><br /> <span>{% trans "hi" %}</span><br /> <a href="#" onclick="submit()">translate</a><br /> </body> <script type="text/javascript"> function submit() { document.getElementById("myform").submit(); } </script>
然后把views中返回值增加一下 return render_to_response("hello.html", {"hi": _("hi"), LANGUAGES: settings.LANGUAGES, LANGUAGE_CODE: request.LANGUAGE_CODE})
最后进行测试,重启服务器,打开浏览器,点击translate就可以切换中英文了.
新闻热点
疑难解答