自python2.6開始,新增了一種格式化字串的函式str.format(),可謂威力十足。那麼,他跟之前的%型格式化字串相比,有什麼優越的存在呢?讓我們來揭開它羞答答的面紗。
語法
它通過{}和:來代替%。
「對映」示例
通過位置
in [1]: ','.format('kzc',18)out[1]: 'kzc,18'
in [2]: '{},{}'.format('kzc',18)
out[2]: 'kzc,18'
in [3]: ',,'.format('kzc',18)
out[3]: '18,kzc,18'
字串的format函式可以接受不限個引數,位置可以不按順序,可以不用或者用多次,不過2.6不能為空{},2.7才可以。
通過關鍵字引數
in [5]: ','.format(age=18,name='kzc')out[5]: 'kzc,18'
通過物件屬性
class person:def __init__(self,name,age):
self.name,self.age = name,age
def __str__(self):
return 'this guy is ,is old'.format(self=self)
in [2]: str(person('kzc',18))out[2]: 'this guy is kzc,is 18 old'
通過下標
in [7]: p=['kzc',18]in [8]: ','.format(p)
out[8]: 'kzc,18'
有了這些便捷的「對映」方式,我們就有了偷懶利器。基本的python知識告訴我們,list和tuple可以通過「打散」成普通引數給函式,而dict可以打散成關鍵字引數給函式(通過和*)。所以可以輕鬆的傳個list/tuple/dict給format函式。非常靈活。
格式限定符
它有著豐富的的「格式限定符」(語法是{}中帶:號),比如:
填充與對齊
填充常跟對齊一起使用
^、<、>分別是居中、左對齊、右對齊,後面帶寬度
:號後面帶填充的字元,只能是乙個字元,不指定的話預設是用空格填充
比如
in [15]: ''.format('189')out[15]: ' 189'
in [16]: ''.format('189')
out[16]: '00000189'
in [17]: ''.format('189')
out[17]: 'aaaaa189'
精度與型別f
精度常跟型別f一起使用
in [44]: ''.format(321.33345)out[44]: '321.33'
其中.2表示長度為2的精度,f表示float型別。
其他型別
主要就是進製了,b、d、o、x分別是二進位制、十進位制、八進位制、十六進製制。
in [54]: ''.format(17)out[54]: '10001'
in [55]: ''.format(17)
out[55]: '17'
in [56]: ''.format(17)
out[56]: '21'
in [57]: ''.format(17)
out[57]: '11'
用,號還能用來做金額的千位分隔符。
in [47]: ''.format(1234567890)out[47]: '1,234,567,890'
Python中用format函式格式化字串
自python2.6開始,新增了一種格式化字串的函式 str.format 可謂威力十足。那麼,他跟之前的 型格式化字串相比,有什麼優越的存在呢?讓我們來揭開它羞答答的面紗。語法 它通過 和 來代替 對映 示例通過位置 12345 6in 1 format kzc 18 out 1 kzc,18 i...
Python中用format 格式化字串
自python2.6開始,新增了一種格式化字串的函式str.format 可謂威力十足。那麼,他跟之前的 型格式化字串相比,有什麼優越的存在呢?它通過 和 來代替 in 1 format zw 20 out 1 zw,20 in 2 format zw 20 out 2 zw,20 in 3 for...
Oracle中用rownum替代Top函式的方法
今天寫乙個方法,主要功能是從資料庫中根據條件查出第一條資訊。以前用sql server的時候,我記得top方法還是非常簡單實用的。方法是 select top n 列名 from 表名 where 查詢條件 這個方法想必像我這樣的新人也會非常熟悉,所以就不做解釋了。今天用的資料庫是oracle。其使...