自 python 2.6 開始,新增了一種格式化字符串的函數str.format()
,可謂威力十足。那麼,他跟以前的%
型格式化字符串相比,有什麼優越的存在呢?讓咱們來揭開它羞答答的面紗。
#語法
它經過{}
和:
來代替%
。python
位置函數
'{0},{1}'.format('kzc',18) # kzc,18 '{},{}'.format('kzc',18) # kzc,18 '{1},{0},{1}'.format('kzc',18) # 18,kzc,18
字符串的 format 函數能夠接受不限個參數,位置能夠不按順序,能夠不用或者用屢次,不過2.6不能爲空{}
,2.7才能夠。spa
參數名.net
'{name}, {age}'.format(age=18,name='kzc') # 'kzc, 18'
對象屬性code
class Person: def __init__(self,name,age): self.name,self.age = name,age def __str__(self): return 'This guy is {self.name},is {self.age} old'.format(self=self)
str(Person('kzc',18)) # 'This guy is kzc,is 18 old'
對象下標orm
arg_arr = ["kevin", 26] msg = "name: {0[0]}, age: {0[1]}".format(arg_arr) #name: kevin, age: 26
有了這些便捷的「映射」方式,咱們就有了偷懶利器。基本的 python 知識告訴咱們,list 和 tuple 能夠經過「打散」成普通參數給函數,而 dict 能夠打散成關鍵字參數給函數(經過和 * )。因此能夠輕鬆的傳個 list/tuple/dict 給 format 函數。很是靈活。對象
格式限定符blog
它有着豐富的的「格式限定符」(語法是{}中帶:號),好比:字符串
填充與對齊it
填充常跟對齊一塊兒使用
對齊
< (默認)左對齊
> 右對齊
^ 中間對齊
= (只用於數字)在小數點後進行補齊
填充
: 後面帶填充的字符,只能是一個字符,不指定的話默認是用空格填充
'{:>8}'.format('189') # ' 189' '{:0>8}'.format('189') # 00000189 '{:a>8}'.format('189') # aaaaa189
精度與類型f
精度常跟類型f一塊兒使用
'{:.2f}'.format(321.33345) # 321.33
其中 .2 表示長度爲 2 的精度,f 表示 float 類型。
進制
b
、d
、o
、x
分別是二進制、十進制、八進制、十六進制。
'{:b}'.format(17) # 10001 '{:d}'.format(17) # 17 '{:o}'.format(17) # 21 '{:x}'.format(17) # 11
用,
號還能用來作金額的千位分隔符。
'{:,}'.format(1234567890) # 1,234,567,890
數據類型
b:二進制。將數字以2爲基數進行輸出。
c:字符。在打印以前將整數轉換成對應的Unicode字符串。
d:十進制整數。將數字以10爲基數進行輸出。
o:八進制。將數字以8爲基數進行輸出。
x:十六進制。將數字以16爲基數進行輸出,9以上的位數用小寫字母。
e:冪符號。用科學計數法打印數字。用’e’表示冪。
g:通常格式。將數值以fixed-point格式輸出。當數值特別大的時候,用冪形式打印。
n:數字。當值爲整數時和’d’相同,值爲浮點數時和’g’相同。不一樣的是它會根據區域設置插入數字分隔符。
%:百分數。將數值乘以100而後以fixed-point(‘f’)格式打印,值後面會有一個百分號。
轉:https://blog.csdn.net/lpw_cn/article/details/84559705