在Python的Django框架中編寫編譯函數(shù)
當(dāng)遇到一個(gè)模板標(biāo)簽(template tag)時(shí),模板解析器就會(huì)把標(biāo)簽包含的內(nèi)容,以及模板解析器自己作為參數(shù)調(diào)用一個(gè)python函數(shù)。 這個(gè)函數(shù)負(fù)責(zé)返回一個(gè)和當(dāng)前模板標(biāo)簽內(nèi)容相對(duì)應(yīng)的節(jié)點(diǎn)(Node)的實(shí)例。
例如,寫一個(gè)顯示當(dāng)前日期的模板標(biāo)簽:{% current_time %}。該標(biāo)簽會(huì)根據(jù)參數(shù)指定的 strftime 格式(參見:http://www.djangoproject.com/r/python/strftime/)顯示當(dāng)前時(shí)間。首先確定標(biāo)簽的語法是個(gè)好主意。 在這個(gè)例子里,標(biāo)簽應(yīng)該這樣使用:
<p>The time is {% current_time "%Y-%m-%d %I:%M %p" %}.</p>
注意
沒錯(cuò), 這個(gè)模板標(biāo)簽是多余的,Django默認(rèn)的 {% now %} 用更簡(jiǎn)單的語法完成了同樣的工作。 這個(gè)模板標(biāo)簽在這里只是作為一個(gè)例子。
這個(gè)函數(shù)的分析器會(huì)獲取參數(shù)并創(chuàng)建一個(gè) Node 對(duì)象:
from django import template register = template.Library() def do_current_time(parser, token): try: # split_contents() knows not to split quoted strings. tag_name, format_string = token.split_contents() except ValueError: msg = '%r tag requires a single argument' % token.split_contents()[0] raise template.TemplateSyntaxError(msg) return CurrentTimeNode(format_string[1:-1])
這里需要說明的地方很多:
每個(gè)標(biāo)簽編譯函數(shù)有兩個(gè)參數(shù),parser和token。parser是模板解析器對(duì)象。 我們?cè)谶@個(gè)例子中并不使用它。 token是正在被解析的語句。
token.contents 是包含有標(biāo)簽原始內(nèi)容的字符串。 在我們的例子中,它是 'current_time "%Y-%m-%d %I:%M %p"' 。
token.split_contents() 方法按空格拆分參數(shù)同時(shí)保證引號(hào)中的字符串不拆分。 應(yīng)該避免使用 token.contents.split() (僅使用Python的標(biāo)準(zhǔn)字符串拆分)。 它不夠健壯,因?yàn)樗皇呛?jiǎn)單的按照所有空格進(jìn)行拆分,包括那些引號(hào)引起來的字符串中的空格。
這個(gè)函數(shù)可以拋出 django.template.TemplateSyntaxError ,這個(gè)異常提供所有語法錯(cuò)誤的有用信息。
不要把標(biāo)簽名稱硬編碼在你的錯(cuò)誤信息中,因?yàn)檫@樣會(huì)把標(biāo)簽名稱和你的函數(shù)耦合在一起。 token.split_contents()[0]總是記錄標(biāo)簽的名字,就算標(biāo)簽沒有任何參數(shù)。
這個(gè)函數(shù)返回一個(gè) CurrentTimeNode (稍后我們將創(chuàng)建它),它包含了節(jié)點(diǎn)需要知道的關(guān)于這個(gè)標(biāo)簽的全部信息。 在這個(gè)例子中,它只是傳遞了參數(shù) "%Y-%m-%d %I:%M %p" 。模板標(biāo)簽開頭和結(jié)尾的引號(hào)使用 format_string[1:-1] 除去。
模板標(biāo)簽編譯函數(shù) 必須 返回一個(gè) Node 子類,返回其它值都是錯(cuò)的。
相關(guān)文章
python?lazypredict構(gòu)建大量基本模型簡(jiǎn)化機(jī)器學(xué)習(xí)
這篇文章主要介紹了python?lazypredict構(gòu)建大量基本模型簡(jiǎn)化機(jī)器學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01使用matplotlib動(dòng)態(tài)刷新指定曲線實(shí)例
這篇文章主要介紹了使用matplotlib動(dòng)態(tài)刷新指定曲線實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-04-04Python數(shù)據(jù)類型--字典dictionary
這篇文章主要介紹了Python數(shù)據(jù)類型字典dictionary,字典是另一種可變?nèi)萜髂P停铱纱鎯?chǔ)任意類型對(duì)象。下面詳細(xì)內(nèi)容需要的小伙伴可以參考一下,希望對(duì)你有所幫助2022-02-02python目標(biāo)檢測(cè)yolo2詳解及預(yù)測(cè)代碼復(fù)現(xiàn)
這篇文章主要為大家介紹了python目標(biāo)檢測(cè)yolo2詳解及其預(yù)測(cè)代碼復(fù)現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05Python的數(shù)據(jù)結(jié)構(gòu)與算法的隊(duì)列詳解(3)
這篇文章主要為大家詳細(xì)介紹了Python的隊(duì)列,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03Python身份運(yùn)算符is與is?not區(qū)別用法基礎(chǔ)教程
這篇文章主要為大家介紹了Python身份運(yùn)算符is與is?not區(qū)別用法基礎(chǔ)教程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06python實(shí)現(xiàn)簡(jiǎn)單飛行棋
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)簡(jiǎn)單飛行棋,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-02-02