在Python的Django框架中創(chuàng)建語(yǔ)言文件
當(dāng)你標(biāo)記了翻譯字符串,你就需要寫出(或獲取已有的)對(duì)應(yīng)的語(yǔ)言翻譯信息。 這里就是它如何工作的。
地域限制
Django不支持把你的應(yīng)用本地化到一個(gè)連它自己都還沒(méi)被翻譯的地域。 在這種情況下,它將忽略你的翻譯文件。 如果你想嘗試這個(gè)并且Django支持它,你會(huì)不可避免地見(jiàn)到這樣一個(gè)混合體––參雜著你的譯文和來(lái)自Django自己的英文。 如果你的應(yīng)用需要你支持一個(gè)Django中沒(méi)有的地域,你將至少需要做一個(gè)Django core的最小翻譯。
消息文件
第一步,就是為一種語(yǔ)言創(chuàng)建一個(gè)信息文件。 信息文件是包含了某一語(yǔ)言翻譯字符串和對(duì)這些字符串的翻譯的一個(gè)文本文件。 信息文件以 .po 為后綴名。
Django中帶有一個(gè)工具, bin/make-messages.py ,它完成了這些文件的創(chuàng)建和維護(hù)工作。 運(yùn)行以下命令來(lái)創(chuàng)建或更新一個(gè)信息文件:
django-admin.py makemessages -l de
其中 de 是所創(chuàng)建的信息文件的語(yǔ)言代碼。 在這里,語(yǔ)言代碼是以本地格式給出的。 例如,巴西地區(qū)的葡萄牙語(yǔ)為 pt_BR ,澳大利亞地區(qū)的德語(yǔ)為 de_AT 。
這段腳本應(yīng)該在三處之一運(yùn)行:
- Django項(xiàng)目根目錄。
- 您Django應(yīng)用的根目錄。
- django 根目錄(不是Subversion檢出目錄,而是通過(guò) $PYTHONPATH 鏈接或位于該路徑的某處)。 這僅和你為Django自己創(chuàng)建一個(gè)翻譯時(shí)有關(guān)。
這段腳本遍歷你的項(xiàng)目源樹或你的應(yīng)用程序源樹并且提取出所有為翻譯而被標(biāo)記的字符串。 它在 locale/LANG/LC_MESSAGES 目錄下創(chuàng)建(或更新)了一個(gè)信息文件。針對(duì)上面的de,應(yīng)該是locale/de/LC_MESSAGES/django.po。
作為默認(rèn), django-admin.py makemessages 檢測(cè)每一個(gè)有 .html 擴(kuò)展名的文件。 以備你要重載缺省值,使用 --extension 或 -e 選項(xiàng)指定文件擴(kuò)展名來(lái)檢測(cè)。
django-admin.py makemessages -l de -e txt
用逗號(hào)和(或)使用-e或--extension來(lái)分隔多項(xiàng)擴(kuò)展名:
django-admin.py makemessages -l de -e html,txt -e xml
當(dāng)創(chuàng)建JavaScript翻譯目錄時(shí),你需要使用特殊的Django域:not -e js 。
沒(méi)有g(shù)ettext?
如果沒(méi)有安裝 gettext 組件, make-messages.py 將會(huì)創(chuàng)建空白文件。 這種情況下,安裝 gettext 組件或只是復(fù)制英語(yǔ)信息文件( conf/locale/en/LC_MESSAGES/django.po )來(lái)作為一個(gè)起點(diǎn);只是一個(gè)空白的翻譯信息文件而已。
工作在Windows上么?
如果你正在使用Windows,且需要安裝GNU gettext共用程序以便 django-admin makemessages 可以工作,請(qǐng)參看下面Windows小節(jié)中g(shù)ettext部分以獲得更多信息。
.po 文件格式很直觀。 每個(gè) .po 文件包含一小部分的元數(shù)據(jù),比如翻譯維護(hù)人員的聯(lián)系信息,而文件的大部分內(nèi)容是簡(jiǎn)單的翻譯字符串和對(duì)應(yīng)語(yǔ)言翻譯結(jié)果的映射關(guān)系的列表。
舉個(gè)例子,如果Django應(yīng)用程序包括一個(gè) "Welcome to my site." 的待翻譯字符串 ,像這樣:
_("Welcome to my site.")
則django-admin.py makemessages將創(chuàng)建一個(gè) .po 文件來(lái)包含以下片段的消息:
#: path/to/python/module.py:23 msgid "Welcome to my site." msgstr ""
快速解釋:
- msgid 是在源文件中出現(xiàn)的翻譯字符串。 不要做改動(dòng)。
- msgstr 是相應(yīng)語(yǔ)言的翻譯結(jié)果。 剛創(chuàng)建時(shí)它只是空字符串,此時(shí)就需要你來(lái)完成它。 注意不要丟掉語(yǔ)句前后的引號(hào)。
- 作為方便之處,每一個(gè)消息都包括:以 # 為前綴的一個(gè)注釋行并且定位上邊的msgid 行,文件名和行號(hào)。
對(duì)于比較長(zhǎng)的信息也有其處理方法。 msgstr (或 msgid )后緊跟著的字符串為一個(gè)空字符串。 然后真正的內(nèi)容在其下面的幾行。 這些字符串會(huì)被直接連在一起。 同時(shí),不要忘了字符串末尾的空格,因?yàn)樗鼈儠?huì)不加空格地連到一起。
若要對(duì)新創(chuàng)建的翻譯字符串校驗(yàn)所有的源代碼和模板,并且更新所有語(yǔ)言的信息文件,可以運(yùn)行以下命令:
django-admin.py makemessages -a
編譯信息文件
創(chuàng)建信息文件之后,每次對(duì)其做了修改,都需要將它重新編譯成一種更有效率的形式,供 gettext 使用??梢允褂胐jango-admin.py compilemessages完成。
這個(gè)工具作用于所有有效的 .po 文件,創(chuàng)建優(yōu)化過(guò)的二進(jìn)制 .mo 文件供 gettext 使用。在你可以運(yùn)行django-admin.py makemessages的目錄下,運(yùn)行django-admin.py compilemessages:
django-admin.py compilemessages
就是這樣了。 你的翻譯成果已經(jīng)可以使用了。
編譯信息文件
創(chuàng)建信息文件之后,每次對(duì)其做了修改,都需要將它重新編譯成一種更有效率的形式,供 gettext 使用。可以使用django-admin.py compilemessages完成。
這個(gè)工具作用于所有有效的 .po 文件,創(chuàng)建優(yōu)化過(guò)的二進(jìn)制 .mo 文件供 gettext 使用。在你可以運(yùn)行django-admin.py makemessages的目錄下,運(yùn)行django-admin.py compilemessages:
django-admin.py compilemessages
就是這樣了。 你的翻譯成果已經(jīng)可以使用了。
- python Django 創(chuàng)建應(yīng)用過(guò)程圖示詳解
- python使用Pycharm創(chuàng)建一個(gè)Django項(xiàng)目
- 使用PyCharm創(chuàng)建Django項(xiàng)目及基本配置詳解
- Django在win10下的安裝并創(chuàng)建工程
- Django中ORM表的創(chuàng)建和增刪改查方法示例
- 在Django中創(chuàng)建動(dòng)態(tài)視圖的教程
- 在Python的Django框架中創(chuàng)建和使用模版
- 詳解在Python的Django框架中創(chuàng)建模板庫(kù)的方法
- 使用python搭建Django應(yīng)用程序步驟及版本沖突問(wèn)題解決
- 在Django框架中運(yùn)行Python應(yīng)用全攻略
- Docker部署Django應(yīng)用的示例
- django框架創(chuàng)建應(yīng)用操作示例
相關(guān)文章
Python 腳本實(shí)現(xiàn)淘寶準(zhǔn)點(diǎn)秒殺功能
這篇文章主要介紹了python實(shí)現(xiàn)淘寶準(zhǔn)點(diǎn)秒殺腳本,本文圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-11-11Python計(jì)算機(jī)視覺(jué)SIFT尺度不變的圖像特征變換
這篇文章主要為大家介紹了Python計(jì)算機(jī)視覺(jué)SIFT尺度不變的圖像特征變換,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05Python函數(shù)關(guān)鍵字參數(shù)及用法詳解
本文主要介紹了Python函數(shù)關(guān)鍵字參數(shù)及用法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03Keras load_model 導(dǎo)入錯(cuò)誤的解決方式
這篇文章主要介紹了Keras load_model 導(dǎo)入錯(cuò)誤的解決方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-06-06Pytorch四維Tensor轉(zhuǎn)圖片并保存方式(維度順序調(diào)整)
這篇文章主要介紹了Pytorch四維Tensor轉(zhuǎn)圖片并保存方式(維度順序調(diào)整),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12Python如何實(shí)現(xiàn)小程序 無(wú)限求和平均
這篇文章主要介紹了python如何實(shí)現(xiàn)小程序 無(wú)限求和平均,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02python基礎(chǔ)教程之基本數(shù)據(jù)類型和變量聲明介紹
這篇文章主要介紹了python基礎(chǔ)教程之基本數(shù)據(jù)類型和變量聲明介紹,首先講解了變量聲明的一些知識(shí),然后列出最常用的基本數(shù)據(jù)類型,需要的朋友可以參考下2014-08-08python pandas輕松通過(guò)特定列的值多條件去篩選數(shù)據(jù)及contains方法的使用
這篇文章主要介紹了python pandas輕松通過(guò)特定列的值多條件去篩選數(shù)據(jù)及contains方法的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02