黑马程序员技术交流社区

标题: 【上海校区】Django 中的国际化的使用 [打印本页]

作者: 会飞的小老虎1    时间: 2020-2-20 18:18
标题: 【上海校区】Django 中的国际化的使用
本帖最后由 会飞的小老虎1 于 2020-2-21 10:52 编辑

Django 国际化使用的翻译模块是使用 Python 自带的 gettext 标准模块。通过一个到 GNU gettext 消息目录库的接口,这个模块为 Python 程序提供了国际化 (I18N) 和本地化 (L10N)。
开发人员和翻译人员需要完成一下 3 个步骤:
安装配置gettext
Django框架具有很好的I18N和L10N的支持,其实现是基于GNU的gettext,所以要想在Django中使用I18N还需要先安装配置gettext。
Windows下的gettext(linux下可能不用安装)从http://sourceforge.net/projects/gettext下载以下zip文件
gettext-runtime-0.17.zip: http://ftp.gnome.org/pub/gnome/binaries/win32/dependencies/gettext-runtime-0.17.zip
gettext-tools-0.17.zip: http://ftp.gnome.org/pub/gnome/binaries/win32/dependencies/gettext-tools-0.17.zip
解压文件
修改settings.py配置settings.py
[Python] 纯文本查看 复制代码
MIDDLEWARE_CLASSES = (
    ...
    'django.middleware.locale.LocaleMiddleware',
)


LANGUAGE_CODE = 'en'
TIME_ZONE = 'UTC'
USE_I18N = True
USE_L10N = True
USE_TZ = True

LANGUAGES = (
    ('en', ('English')),
    ('zh-Hans', ('中文简体')),
    ('zh-Hant', ('中文繁體')),   
)

LOCALE_PATHS = (
    os.path.join(BASE_DIR, 'locale'),  #翻译文件所在目录,请自行创建
)

TEMPLATE_CONTEXT_PROCESSORS = (
    ...
    "django.core.context_processors.i18n",
)


示例模板:在模板中使用, 需要先{% load i18n %}, 然后你可使用:trans和blocktrans模板标记。
更多的使用方法可以参考: http://python.usyiyi.cn/documents/django_182/topics/i18n/translation.html#std:templatetag-blocktrans


示例模板文件base.html
[HTML] 纯文本查看 复制代码
{% load i18n %}
<!DOCTYPE html>
<html lang="en">
<head>
    <title>{% trans "Home" %}</title>
</head>
<body>
</body>
</html>

生成需要翻译的文件manage.py makemessages -l zh_Hans
manage.py makemessages -l zh_Hant
此时, 将会在项目根目录下生成两个文件夹, 如zh_hans(简体汉字):

手工翻译locale中的对应语言的django.po文件


编译一下,这样翻译才会生效python manage.py compilemessages
注意:
如果翻译不生效,请检查你的语言包的文件夹是不是有 中划线,请用下划线代替它。
比如 zh-hans 改成 zh_hans (但是要注意 setttings.py 中要用 中划线,不要也改了)







欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2