亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Django中的“惰性翻譯”方法的相關(guān)使用

 更新時(shí)間:2015年07月27日 15:39:29   投稿:goldensun  
這篇文章主要介紹了Django中的“惰性翻譯”方法的相關(guān)使用,Django是最具人氣的Python web開發(fā)框架,需要的朋友可以參考下

使用 django.utils.translation.gettext_lazy() 函數(shù),使得其中的值只有在訪問時(shí)才會(huì)被翻譯,而不是在 gettext_lazy() 被調(diào)用時(shí)翻譯。

例如:要翻譯一個(gè)模型的 help_text,按以下進(jìn)行:

from django.utils.translation import ugettext_lazy

class MyThing(models.Model):
  name = models.CharField(help_text=ugettext_lazy('This is the help text'))

在這個(gè)例子中, ugettext_lazy() 將字符串作為惰性參照存儲(chǔ),而不是實(shí)際翻譯。 翻譯工作將在字符串在字符串上下文中被用到時(shí)進(jìn)行,比如在Django管理頁面提交模板時(shí)。

在Python中,無論何處你要使用一個(gè)unicode 字符串(一個(gè)unicode 類型的對(duì)象),您都可以使用一個(gè) ugettext_lazy() 調(diào)用的結(jié)果。 一個(gè)ugettext_lazy()對(duì)象并不知道如何把它自己轉(zhuǎn)換成一個(gè)字節(jié)串。如果你嘗試在一個(gè)需要字節(jié)串的地方使用它,事情將不會(huì)如你期待的那樣。 同樣,你也不能在一個(gè)字節(jié)串中使用一個(gè) unicode 字符串。所以,這同常規(guī)的Python行為是一致的。 例如:

# This is fine: putting a unicode proxy into a unicode string.
u"Hello %s" % ugettext_lazy("people")

# This will not work, since you cannot insert a unicode object
# into a bytestring (nor can you insert our unicode proxy there)
"Hello %s" % ugettext_lazy("people")

如果你曾經(jīng)見到到像"hello"這樣的輸出,你就可能在一個(gè)字節(jié)串中插入了ugettext_lazy()的結(jié)果。 在您的代碼中,那是一個(gè)漏洞。

如果覺得 gettext_lazy 太過冗長(zhǎng),可以用 _ (下劃線)作為別名,就像這樣:

from django.utils.translation import ugettext_lazy as _

class MyThing(models.Model):
  name = models.CharField(help_text=_('This is the help text'))

在Django模型中總是無一例外的使用惰性翻譯。 為了翻譯,字段名和表名應(yīng)該被標(biāo)記。(否則的話,在管理界面中它們將不會(huì)被翻譯) 這意味著在Meta類中顯式地編寫verbose_nane和verbose_name_plural選項(xiàng),而不是依賴于Django默認(rèn)的verbose_name和verbose_name_plural(通過檢查model的類名得到)。

from django.utils.translation import ugettext_lazy as _

class MyThing(models.Model):
  name = models.CharField(_('name'), help_text=_('This is the help text'))
  class Meta:
    verbose_name = _('my thing')
    verbose_name_plural = _('mythings')

相關(guān)文章

  • 在Django中管理Users和Permissions以及Groups的方法

    在Django中管理Users和Permissions以及Groups的方法

    這篇文章主要介紹了在Django中管理Users和Permissions以及Groups的方法,Django是最具人氣的Python web開發(fā)框架,需要的朋友可以參考下
    2015-07-07
  • 深入分析python數(shù)據(jù)挖掘 Json結(jié)構(gòu)分析

    深入分析python數(shù)據(jù)挖掘 Json結(jié)構(gòu)分析

    這篇文章通過實(shí)例給大家分析總結(jié)了python數(shù)據(jù)挖掘以及Json結(jié)構(gòu)分析的相關(guān)知識(shí)點(diǎn),對(duì)此有興趣的朋友參考下。
    2018-04-04
  • 詳解基于K-means的用戶畫像聚類模型

    詳解基于K-means的用戶畫像聚類模型

    這篇文章主要介紹了基于K-means的用戶畫像聚類模型,本文中就是使用one-hot思想將不同維度的數(shù)據(jù)利用字典映射的方式將其轉(zhuǎn)化為數(shù)據(jù)向量,需要的朋友可以參考下
    2022-05-05
  • Python高效處理大文件的方法詳解

    Python高效處理大文件的方法詳解

    在這篇文章中,我們將學(xué)習(xí)如何使用multiprocessing、joblib和tqdm?Python包減少大文件的處理時(shí)間。這是一個(gè)簡(jiǎn)單的教程,可以適用于任何文件、數(shù)據(jù)庫、圖像、視頻和音頻,感興趣的可以了解一下
    2022-07-07
  • TensorFlow車牌識(shí)別完整版代碼(含車牌數(shù)據(jù)集)

    TensorFlow車牌識(shí)別完整版代碼(含車牌數(shù)據(jù)集)

    這篇文章主要介紹了TensorFlow車牌識(shí)別完整版代碼(含車牌數(shù)據(jù)集),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • numpy.array 操作使用簡(jiǎn)單總結(jié)

    numpy.array 操作使用簡(jiǎn)單總結(jié)

    這篇文章主要介紹了numpy.array 操作使用簡(jiǎn)單總結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • Python struct.unpack

    Python struct.unpack

    Python中按一定的格式取出某字符串中的子字符串,使用struck.unpack是非常高效的。
    2008-09-09
  • python中的netCDF4批量處理NC文件的操作方法

    python中的netCDF4批量處理NC文件的操作方法

    這篇文章主要介紹了python的netCDF4批量處理NC格式文件的操作方法,使用python批量提取所有數(shù)據(jù),查看數(shù)據(jù)屬性,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-03-03
  • widows下安裝pycurl并利用pycurl請(qǐng)求https地址的方法

    widows下安裝pycurl并利用pycurl請(qǐng)求https地址的方法

    今天小編就為大家分享一篇widows下安裝pycurl并利用pycurl請(qǐng)求https地址的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • python的類方法和靜態(tài)方法

    python的類方法和靜態(tài)方法

    這篇文章主要介紹了python的類方法和靜態(tài)方法,以實(shí)例形式分析了Python中類方法和靜態(tài)方法的實(shí)現(xiàn)技巧與應(yīng)用方法,需要的朋友可以參考下
    2014-12-12

最新評(píng)論