
“專業人士筆記”系列目錄:
創帆云:Python成為專業人士筆記--強烈建議收藏!每日持續更新!?zhuanlan.zhihu.com
在存儲和轉換數據輸出供查看時,字符串格式可能變得非常重要。Python提供了本文概述的各種字符串格式化方法
基礎字符串格式化
foo = 1bar = 'bar'baz = 3.14
可以使用str.format來格式化輸出。括號對里按傳遞參數的順序進行替換:
foo = 1
bar = 'bar'
baz = 3.14print('{}, {} and {}'.format(foo, bar, baz))
#輸出: "1, bar and 3.14"
還可以在括號內指定索引。下面的這些數字對應于傳遞給str.format函數(從0開始)的參數的順序
foo = 1
bar = 'bar'
baz = 3.14 print('{0}, {1}, {2}, and {1}'.format(foo, bar, baz))
#輸出: "1, bar, 3.14, and bar"print('{0}, {1}, {2}, and {3}'.format(foo, bar, baz))
#:報錯 index out of range error 參數中并沒有
也可以使用命名參數 :
print("X value is: {x_val}. Y value is: {y_val}.".format(x_val=2, y_val=3))
#輸出: "X value is: 2. Y value is: 3."
對象屬性可以在傳遞到str.format中進行引用:
class AssignValue(object):def __init__(self, value):self.value = value #這里定義了value對象屬性my_value = AssignValue(6)
print('My value is: {.value}'.format(my_value)) #將對象作為參數傳入后,可以使用.value訪問對象的values屬性
當然也可以使用字典傳入并引用鍵,注意其引用的寫法:
my_dict = {'key': 6, 'other_key': 7}
print("My other key is: {[key]}".format(my_dict))#輸出:My other key is: 6
list列表和tuple元組,都一樣的引用:
my_list = ['zero', 'one', 'two']
print("2nd element is: {[2]}".format(my_list))#輸出:2nd element is: two
除了參數索引之外,還可以在花括號中包含格式規范。這是一個表達式,它遵循特殊的規則,并且必須在前面加上冒號(:)。有關格式規范的完整描述,請參閱文檔。格式規范的一個例子是對齊指令: ~^20(其中^代表以中心對齊,兩邊都填充~字符, 總長度為20 )
print(‘{:~^20}’.format(‘centered’))
#輸出:~~centered~~
由于format是一個函數,所以它可以用作其他函數的參數 :
number_list = [12, 45, 78]
print(list(map('the number is {}'.format, number_list)))
# 輸出: ['the number is 12', 'the number is 45', 'the number is 78']from datetime import datetime, timedeltaonce_upon_a_time = datetime(2010, 7, 1, 12, 0, 0)
delta = timedelta(days=13, hours=8, minutes=20)gen = (once_upon_a_time + x * delta for x in range(5))print('n'.join(map('{:%Y-%m-%d %H:%M:%S}'.format, gen)))# 輸出: 2010-07-01 12:00:00
# 2010-07-14 20:20:00
# 2010-07-28 04:40:00
# 2010-08-10 13:00:00
# 2010-08-23 21:20:00
用 f 格式化文本
foo = 'bar'
print(f'Foo is {foo}')#輸出:Foo is bar# 這也適用于更高級的格式字符串,包括對齊和點符號print(f'{foo:^7s}') #輸出:bar
格式字符串也可以嵌套 :
price = 478.23
print(f"{f'${price:0.2f}':*>20s}")#輸出:**************$478.23
Float 格式化
print('{:.0f}'.format(42.12345))
#42print('{:.1f}'.format(42.12345))
#42.1
函數作為命令參數時的引用方式:
print('{a:.3f}'.format(a=42.12345,b=232))
#42.123
浮點數也可以用科學計算符號或百分數來格式化:
print('{:.3e}'.format(42.12345))
#4.212e+01print('{:.0%}'.format(42.12345))
#4212%
你還可以組合使用{0}和{name}符號。當您希望用一個聲明將所有變量四舍五入到預先指定的小數位數時,這尤其有用 :
s = 'Hello'
a, b, c = 1.12345, 2.34567, 34.5678
digits = 2print('{0}! {1:.{n}f}, {2:.{n}f}, {3:.{n}f}'.format(s, a, b, c, n=digits))#輸出:Hello! 1.12, 2.35, 34.57
命名占位符
格式字符串可以包含命名占位符,這些占位符通過使用關鍵字參數進行格式轉化,先看下面的例子:
#使用字典作為內置format_map函數的參數
data = {'first': 'zhou', 'last': 'fan!'}
print('{first} {last}'.format_map(data))#輸出:zhou fan!#使用命名空間作為內置format函數(注意不是format_map) 的參數
print('{first} {last}'.format(first='zhou',last='fan'))#輸出:zhou fan
因此,內置format_map函數允許使用字典而無需先解析它
datatime格式的字符串
任何類都可以通過format方法配置自己的字符串格式語法。標準Python庫中可以方便地使用這種格式的一種類型是:datetime類型,在這種類型中可以直接在str.format中使用等效于strftime的格式化代碼
from datetime import datetime
print('North America: {dt:%m/%d/%Y}. ISO: {dt:%Y-%m-%d}.'.format(dt=datetime.now()))#輸出:North America: 05/19/2020. ISO: 2020-05-19.
Numerical格式化
format()方法可以將數字解析成不同的格式,例如 :
print('{:c}'.format(65))# 解析成Unicode 字符print('{:b}'.format(10))# 解析成二進制#輸出:
A
1010
利用類自定義格式化
注意:下面的所有內容都適用于str.format方法以及format函數。在下面的文本中,兩者是可以互換的
對于傳遞給format函數的每個值,Python都會為該參數尋找一個__format__方法。因此,你完全可以自定義類的__format__方法來確定format函數將如何顯示和格式化類及其屬性
但是,其實現與str方法的實現完全不同,因為在__format__方法中,你可以考慮以什么樣的方式格式化對象,包括對齊方式、字段寬度等,甚至(如果你愿意的話)實現自己的格式說明符和自己的格式化語言擴展
舉例:
class Example(object):def __init__(self, a, b, c):self.a, self.b, self.c = a, b, cdef __format__(self, format_spec):""" 實現“s”格式說明符的特殊語義 """# 拒絕任何不是s的格式化字符if format_spec[-1] != 's':raise ValueError('{} 不理解的格式說明符 ',format_spec[:-1])# 本例中的輸出將是(<a>,<b>,<c>) raw = "(" + ",".join([str(self.a), str(self.b), str(self.c)]) + ")"# 通過使用內建的字符串格式來重建格式語言 # 因為我們知道原始格式規范以“s”結尾 # 我們可以利用上面構造的string參數來使用str.format方法 return "{r:{f}}".format(r=raw, f=format_spec)inst = Example(1, 2, 3)
print("{:>20s}".format(inst))
# 輸出 : (1,2,3)
# 請注意如何使用右對齊和字段寬度20的格式化串
以上所有代碼均已在python3云環境中調試通過
禁止轉載