Django分析之国际化处理

最近在公司终于开始做web开发了,本以为会是简单的首页之类的小规模项目,结果上来就是一个处理大数据分析的项目,一个关于油品分析的系统,不过我接到的第一个任务是做这个网站的国际化处理,虽然项目还没有上线,还差的很多,但是国际化这个东西使用的是Django自带的来处理的,所以在一边写项目的时候就要写好国际化的代码,所以我现在就开始处理我的国际化了.

大家可以在Django Doctment上看官方的说明,我在这里就不复制官方文档了,django框架带有完善的I18N和L10N支持,其实现是基于GNU gettext的。最近看着文档研究了一下,在这里概要总结一下django国际化的处理流程。

经典用法是把ugettext_lazy导为_使用,该函数标记要翻译的符号,并在要输出该符号的时候进行翻译,返回unicode对象:

1 from django.utils.translation import ugettext as _
2 from django.utils.translation import ugettext_lazy
3
4 label=ugettext_lazy(u"日期")
5 ......
6 opt = {"data": [], "name": _(u‘销售额({first},{last})‘)

需要输出label和opt的地方就会自动转成对应的国际化语言了,现在是在代码里面改好了,那么接下来该怎么使用呢?

紧接着在对应app目录创建locale目录,并按此格式<language>/LC_MESSAGES/创建好欲支持的语言目录,转到app目录下执行django-admin.py makemessages --all 命令, 把所有标记的翻译符号导出为po文件,打开各个<language>/LC_MESSAGES/django.po文件,把符号翻译为对应的本地言语,再执行django-admin.py compilemessages把po文件编译为mo文件,这两个命令一定要在locale的当前目录执行。

那么接下来,就要在settings文件中配置关于国际化的设置了,我们需要在settings文件中这样配置:

 1 USE_I18N = True
 2
 3 USE_L10N = True
 4
 5 LANGUAGE_CODE = ‘zh-cn‘
 6
 7 TIME_ZONE = ‘Asia/Shanghai‘
 8
 9 LANGUAGES = (
10     (‘en‘, ugettext_lazy(u"英文")),
11     (‘zh-cn‘,ugettext_lazy(u"中文")),
12 )
13
14 #是否自动判断Accept-Language头转换语言
15 LOCALEURL_USE_ACCEPT_LANGUAGE=False
16
17 #是否显示语言前缀
18 PREFIX_DEFAULT_LOCALE = True
19
20 #是否在session中保存用户指定的语言
21 LOCALEURL_USE_SESSION=True
22
23 MIDDLEWARE_CLASSES = (
24     ‘django.middleware.gzip.GZipMiddleware‘,
25     ‘django.middleware.common.CommonMiddleware‘,
26     ‘django.contrib.sessions.middleware.SessionMiddleware‘,
27     ‘django.middleware.locale.LocaleMiddleware‘,
28     ‘django.middleware.csrf.CsrfViewMiddleware‘,
29     ‘django.contrib.auth.middleware.AuthenticationMiddleware‘,
30     ‘django.contrib.messages.middleware.MessageMiddleware‘,
31 )
32
33 TEMPLATE_CONTEXT_PROCESSORS = ("django.contrib.auth.context_processors.auth",                                  "django.core.context_processors.debug",                                  "django.core.context_processors.i18n",                                  "django.core.context_processors.media",                                  "django.core.context_processors.static",                                  "django.core.context_processors.tz",                                  "django.contrib.messages.context_processors.messages")

注意:MIDDLEWARE_CLASSES中要增加‘django.middleware.locale.LocaleMiddleware‘,该中间见要出现在SessionMiddleware和CacheMiddleware后,其他所有中间件之前,而TEMPLATE_CONTEXT_PROCESSORS 中要增加 ‘django.core.context_processors.i18n‘.

当你做完以上这些操作你就可以让你的项目成功的显示多语言了,那接下来呢?你会发现实际上项目中还会有一些是无法翻译过来的,那是为什么呢?因为他们都是通过外部的js来渲染进模板中的,这样的话你再使用上面提到的方法就不行了,那么该怎么办呢?下面我就来介绍如何在外部js中做多语言的翻译.

首先,我们要在urls.py文件中这样配置:

url(r‘^jsi18n/(?P<packages>\S+?)/$‘, ‘django.views.i18n.javascript_catalog‘), 

然后在需要国际化的模板页中引入:

    <script type="text/javascript" src="/jsi18n/userauth"></script>  

那么,在这个页面中可以用javascript调用gettext方法实现国际化。/userauth是locale文件所在的路径(可以是app路径,此app应该在settings.py的INSTALL_APP中配置好)。接着,在userauth的locale路径下,如/zh_CN路径下新建djangojs.po文件,将msgid和msgstr的对应关系写入。再利用django-admin.py compilemessages即可以在javascript中利用gettext(‘bug.manage‘)获得它对应的国际化值。

对于Djangojs.py文件的建立我们采用这样的命令:

django-admin.py makemessage -d djangojs -l en

这样,就会在之前我们生成django.py文件的目录里产生一个djangojs.py文件了,这样就可以直接进行翻译了.而对于js文件中的字符串我们采用什么样的方式呢?

var name = String.format("xxxxxx{0}",gettext(‘xxx‘))

到此为止就基本不会再出现什么问题了,那么Django是按照什么样的顺序来确定应该是使用什么样的语言呢?

1,在用户session里查找django_language key

2,如果不存在session,查找django_language cookie

3,查找http头 Accept-Language

4,以后都未设置,使用settings.LANGUAGE_CODE

决定了使用哪种语言后,按如下找顺序查找mo文件:

1,settings LOCALE_PATHS变量指定的路径

2,每个app目录下的locale目录

3,工程目录下的locale目录

4,最后是django/conf/locale目录

当有重复的mo文件时,mo优先级同查找顺序一致,即先找到的会屏蔽其后边的mo项

OK!!基本上关于Django多语言处理的地方都介绍过了,这样就成功的实现了多语言的处理了~~~

时间: 2024-10-09 16:51:32

Django分析之国际化处理的相关文章

Django的文本国际化

1.表示需要翻译的文本:在python原文件和HTML等模板文件中都可以标识需要翻译的文本,在python源文件通过_()或者ueettext()函数表达需要翻译的需求.在模板文件中,用{%trans %}标签表达翻译需求. 2.创建语言文件:语言文件是Django找那个用于保存翻译关系的文件,网站应该为每种支持的语言建立一个语言文件,建立语言文件的方法是在项目根目录中执行如下命令: django -admin makemessages -l zh_CN 该条命令会在当前目录及子目录的pytho

Django分析之使用redis缓存服务器

时间长没有更新了,这段时间一直忙着一个项目,今天就记录一个现在经常会用到的技术吧. redis相信大家都很熟悉了,和memcached一样是一个高性能的key-value数据库,至于什么是缓存服务器,度娘都有很明白的介绍了,我在这里就不一一介绍了. 那我们一般什么情况下才会使用缓存服务器呢?可不是什么情况都需要的哦,一般来说是在需要频繁对一个字段读取的时候才会需要将这个字段放入到缓存服务器上,而且由于key-value数据库一般只是放很简单的数据,所以在选择保存的对象的时候要注意选择好. 下面我

Django分析之Middleware中间件

写了几周的脚本,今天终于开始接触web框架了~学习Python的web框架,那么Django就几乎是必修课了,这次的工作是先打打下手,主要的任务是在setting中添加版本号,在渲染静态css,js的路径时附带版本号,例如“example.v1124.css”,然后再在request请求中祛除掉版本号.为什么要这么做呢?因为这样做的话在前端输出静态文件的路径就会加上就会加上版本号,这样当开发出新的静态文件的时候,客户端就会强制刷新本地的缓存,为了达到这个目的就要首先要在settings文件中配置

Django分析之导出为PDF文件

最近在公司一直忙着做exe安装包,以及为程序添加新功能,好久没有继续来写关于Django的东西了….难得这个周末清闲,来了解了解Django的一些小功能也是极好的了~ 那今天就来看看在Django的视图中将页面导出为pdf格式的功能吧.那么动态生成pdf的好处是什么呢?你可以为不同目的的用户创建定制的pdf.那么是如何实现的呢?它使用的是Python开源的pdf库---ReportLab 安装ReportLab 你可以从http://www.reportlab.com/software/open

Django分析之如何自定义manage命令

我们都用过Django的manage.py的命令,而manage.py是在我们创建Django项目的时候就自动生成在根目录下的一个命令行工具,它可以执行一些简单的命令,其功能是将Django project放到sys.path目录中,同时设置DJANGO_SETTINGS_MODULE环境变量为当前project的setting.py文件.我们来看一下代码: #!/usr/bin/env python import os import sys if __name__ == "__main__&q

Django分析之三级下拉菜单选择省/市/县

今天遇到了一个一直想做却没有机会去做的功能,今天完成了便记录下来. 那这次是具体是个什么功能呢?其实还是很简单的效果,就是在用户注册的时候可以选择省/市/县,很简单的一个小功能. 那现在就开始了~首先我们要在数据库中先建一个表,用来保存全国的省/市/县信息,下面是表的结构: CREATE TABLE IF NOT EXISTS "china_regionalTable" ( "id" integer NOT NULL, "name" varcha

Django Book

The Django Book 2.0--中文版 第一章:介绍Django 本书所讲的是Django:一个可以使Web开发工作愉快并且高效的Web开发框架. 使用Django,使你能够以最小的代价构建和维护高质量的Web应用. 从好的方面来看,Web 开发激动人心且富于创造性:从另一面来看,它却是份繁琐而令人生厌的工作. 通过减少重复的代码,Django 使你能够专注于 Web 应用上有 趣的关键性的东西. 为了达到这个目标,Django 提供了通用Web开发模式的高度抽象,提供了频繁进行的编程

收集了一些python的文章

来自: 戴铭 2010-08-31 17:52:31 newthreading - safer concurrency for Python 安全并发(1回应) http://www.starming.com/index.php?action=plugin&v=wave&tpl=union&ac=viewgrouppost&gid=73&tid=7607 几个 Google App Engine 开源的Blog程序 http://www.starming.com/i

Django-djangorestframework-异常模块-源码及自定义异常

目录 异常模块 为什么要自定义异常模块 常见的几种异常情况 异常模块源码分析 自定义 drf 异常处理 异常模块 为什么要自定义异常模块 所有经过 drf APIView 视图类产生的异常,都可以提供异常处理方案(没有继承 APIVIew 的视图函数不会触发) drf 默认提供了异常处理方案(rest_framework.views.exception_handler),但是处理范围有限 drf 提供的处理方案有两种 有对应处理,处理了返回异常信息 没有对应处理(处理范围之外),返回 None,