关于string.Template的简单介绍
一、簡(jiǎn)介
string模塊定義了一種新字符串類型Template,它簡(jiǎn)化了特定的字符串置換操作。
何謂“簡(jiǎn)化”?我們可以先想一下我們之前比較常用的有關(guān)字符串的“置換”操作有哪些:一種是利用%操作符實(shí)現(xiàn),另外一種是格式化字符串format實(shí)現(xiàn)。那么,相比于這兩種方法,string.Template究竟簡(jiǎn)化在何處呢?
那我們就以下面的代碼為例簡(jiǎn)單說明一下string.Template的用法與上述兩種方式的區(qū)別:
# -*- coding: utf-8 -*- # -*- Author: WangHW -*- import stringvalues = {'var':3.3333333} #1 t1 = string.Template(""" Variable : $var Escape : $$ Variable in text: ${var}iable """) print('TEMPLATE:',t1.substitute(values)) print('############################') #2 s = """ Variable : %(var)s Escape : %% Variable in text: %(var)siable """ print('INTERPOLATION:',s % values) print('############################')#3 s1 = """ Variable {var} Escape : {{}} Variable in text: {var}iable """ print('FORMAT:',s1.format(**values))結(jié)果如下:
上面的代碼分別利用string.Template方法、%操作符以及format方法進(jìn)行了字符串的置換操作。這里我們可以看出string.Template是利用$符號(hào)進(jìn)行“關(guān)聯(lián)”,用substitute方法取值的。
這里直接給出結(jié)論:利用string.Template方法是不需要考慮參數(shù)的數(shù)據(jù)類型的!這是string.Template方法與后面兩種方法最重要的不同之處。string.Template方法直接將參數(shù)轉(zhuǎn)換為字符串格式,然后將轉(zhuǎn)換后的字符串直接插入結(jié)果中去。沒有可用的格式化選項(xiàng)供我們選擇,例如,對(duì)于一個(gè)浮點(diǎn)數(shù)(如上述例子所示)來講,我們沒辦法控制代表這個(gè)浮點(diǎn)數(shù)數(shù)值的位數(shù)。
二、safe_substitute方法
上例中我們利用substitute取值。大家肯定會(huì)問了:如果$關(guān)聯(lián)的字符串在前面定義的values中不存在怎么辦?難道會(huì)報(bào)錯(cuò)嗎?
答案是肯定的!為了避免上述問題的產(chǎn)生我們利用safe_substitute方法取值,當(dāng)然可以跟原生的substitute方法對(duì)比一下:
# -*- coding: utf-8 -*- # -*- Author: WangHW -*- import stringvalues = {'var':'foo'}t = string.Template('$var is here but $missing is not provided')try:print('substitute() :',t.substitute(values)) except KeyError as err:print('ERROR:',str(err))print('safe_substitute():',t.safe_substitute(values))結(jié)果如下:
大家可以看到:values中并沒有代表key的字符串'missing',而我們?cè)赥emplate中卻試圖利用$missing取其對(duì)應(yīng)的值。因此substitute方法會(huì)報(bào)錯(cuò),而safe_substitute方法可以巧妙的“避免”這個(gè)錯(cuò)誤,保證程序的流暢性。
三、進(jìn)階:模塊功能的“修改”
在實(shí)際中,大家可能習(xí)慣利用%操作符去進(jìn)行字符串的置換了,那么,如果我們既想利用string.Template方法的便捷性,又想按照自己的意愿與需求定義額外的功能,這就需要我們新定義一個(gè)繼承自string.Template的類(例如命名為MyTempate),在這里修改其中的某些屬性去滿足我們的需求。
下面代碼中MyTemplate類繼承自string.Template,修改了操作符delimiter與id模式idpattern,實(shí)現(xiàn)了利用%關(guān)聯(lián)代表key的字符串,然后利用正則表達(dá)式使safe_substitute()只能匹配出帶下劃線的且由a-z組成的字符串:
# -*- coding: utf-8 -*- # -*- Author: WangHW -*- import stringclass MyTemplate(string.Template):#操作符delimiter = '%'#id模式idpattern = '[a-z]+_[a-z]+'if __name__ == '__main__':template_text = '''Delimiter : %%Replaced : %with_underscoreIgnored : %notunderscored'''d = {'with_underscore':'replaced','notunderscored':'not replaced'}t = MyTemplate(template_text)print('Modified ID pattern:')print(t.safe_substitute(d))結(jié)果如下:
上例中,由于代表key的字符串‘notunderscored’沒有下劃線,沒有匹配到,所以結(jié)果中只能得出%notunderscored,不能取到具體的值。
需要注意的是:這種方法在實(shí)際中非常常用!在實(shí)際中我們需要根據(jù)具體的需求靈活的“更改”模塊中某個(gè)對(duì)象的某個(gè)屬性去實(shí)現(xiàn)具體的需求!
轉(zhuǎn)載于:https://www.cnblogs.com/paulwhw/p/9231884.html
總結(jié)
以上是生活随笔為你收集整理的关于string.Template的简单介绍的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 路由器配置——OSPF协议(2)
- 下一篇: c# json.net xml互转