溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Python中如何使用str.format方法

發(fā)布時間:2020-09-24 10:58:03 來源:億速云 閱讀:355 作者:Leah 欄目:編程語言

這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)Python中如何使用str.format方法,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

字符串的內(nèi)置方法大致有40來個,但是一些常用的其實就那么20幾個,而且里面還有類似的用法,區(qū)分度高比如:isalpha,isalnum,isdigit,還有一些無時不刻都會用到的split切分,join拼接,strip首尾去指定字符,作用無非就是圍繞字符串的增刪改查來進(jìn)行,本人認(rèn)為要弄清楚和熟練使用這些常用的方法,一方面需要在理解的基礎(chǔ)上多多練習(xí)多多回顧,同時在工作使用中去鞏固,加深記憶。忘記沒關(guān)系,善于總結(jié)歸納,善于對自己大腦記憶的‘增刪改查’才是重點。

str.format的意義:

作為一個初學(xué)者,最近發(fā)現(xiàn)字符串中最繁雜的一個方法莫過于:str.format()了,format見名思義,格式化,格式化完為了干嘛,其實就是為了得到我們需要格式的數(shù)據(jù),也就是格式化輸出,格式化輸出我們一開始學(xué)習(xí)的是用%s、%d來實現(xiàn),但是這種方法有很多局限性,比如%s是按照位置格式化輸出,局限性顯而易見,如果一次性格式化輸出太多,還是根據(jù)位置來輸出的話就太容易出錯了。所以更精確的一種格式化輸出方法就是str.format()

str.format方法介紹:

1、通過字符串中的花括號{}來識別替換字段,從而完成字符串的格式化。

2、替換的內(nèi)容包括:字段名、格式說明符三部分,形式一般為:{字段名:格式說明符}

以上是簡介,下面是干貨:

具體實現(xiàn):

1、簡單實現(xiàn)方法:

(1)省略不寫{} ____寫法類似%s按位置格式化輸出

(2)數(shù)字{十進(jìn)制非負(fù)整數(shù)} ____寫法類似依據(jù)位置索引傳參

(3)變量名{關(guān)鍵字} ____寫法類似關(guān)鍵字參數(shù)傳參

(4)可以混合使用

1.1 省略不寫:花括號內(nèi)省略不寫,代表傳遞位置參數(shù)

替換字段形式{}

注意事項:花括號個數(shù)少于等于后面的位置參數(shù)的個數(shù),多了肯定報錯。

# 用{}代表占位符,直接位置傳參
print('我是{},喜歡{}!'.format('滅霸','打響指'))
# 我是滅霸,喜歡打響指!
# {}數(shù)量必須少于后面位置參數(shù)數(shù)量,不然報錯
print('我是{},喜歡{},不喜歡{}。'.format('宙斯','放大搶人頭','放空大','小短腿'))
print('我是{},喜歡{},不喜歡{}。'.format('宙斯','放大搶人頭'))
# 報錯誤:IndexError: tuple index out of range

1.2 數(shù)字形式傳參:通過位置索引值傳遞位置參數(shù)

索引從整數(shù)0開始

索引可以重復(fù)引用,輸出

索引數(shù)值就是后面位置參數(shù)放入一個元組來取值的過程,所以索引數(shù)值不能大于元組里面位置參數(shù)的最大索引值,否則報錯

print('我身高{0},年齡正好{1},{2}長。'.format('180cm',18,'15cm'))
# 我身高180cm,年齡正好18,15cm長。
print('我身高{0},{0}不多不少,年齡正好{1}。'.format('180cm',18))
# 我身高180cm,180cm不多不少,年齡正好18。
print('我身高{0},年齡正好{1},{2}長。'.format('180cm',18))
# IndexError: tuple index out of range

1.3 變量名{關(guān)鍵字} 傳遞輸出參數(shù)

想想關(guān)鍵字參數(shù)怎么傳參,類比一下,bingo!

特別注意,關(guān)鍵字的變量名在參數(shù)那里無需加引號,同時{}里面引用直接填變量名。

print('我的名字叫{name},我其實是一名{career}!'.format(name='尹天仇',career='演員'))
# 我的名字叫尹天仇,我其實是一名演員!
print('我叫{name2},又名{name1},我弟弟叫{name3}!'.format(name1='至尊寶',name2='秦漢',name3='秦祥林'))
# 我叫秦漢,又名至尊寶,我弟弟叫秦祥林!

1.4 {}、{0}、{name}混合使用

位置參數(shù)在前,關(guān)鍵字參數(shù)在后

{}不能與數(shù)字形式{0}同時使用。

print('吹個{0},吹個{2},吹大了{(lán)1},玩{ball}!'.format('球','氣球','大氣球',ball='球球'))
# 吹個球,吹個大氣球,吹大了氣球,玩球球!
print('吹個{},吹大了{(lán)},玩{ball}!'.format('球','氣球','大氣球',ball='球球'))
# 吹個球,吹大了氣球,玩球球!
print('吹個{0},吹大了{(lán)1},玩{ball}!'.format('球','氣球','大氣球',ball='球球'))
# 吹個球,吹大了氣球,玩球球!
print('吹個{0},吹大了{(lán)},玩{ball}!'.format('球','氣球','大氣球',ball='球球'))
#報錯 ValueError: cannot switch from manual field specification to automatic field numbering

2、使用元組和字典傳參:

str.format()方法可以使用*元組和**字典的形式傳參,可以混用。

方法相當(dāng)于*args和**kwargs打散傳參,元組按位置或索引傳參,字典按關(guān)鍵字傳參。

位置參數(shù)、關(guān)鍵字參數(shù)、*元組、**字典也可以同時使用,但要注意位置參數(shù)在關(guān)鍵字參數(shù)前,*元組要在**字典前。

# 元組
print('我喜歡{},喜歡{},同時也喜歡{}!'.format(*('籃球','足球','觀球')))
# 我喜歡籃球,喜歡足球,同時也喜歡觀球!
print('我喜歡{0},喜歡{1},同時也喜歡{2}!'.format(*('籃球','足球','觀球')))
# 我喜歡籃球,喜歡足球,同時也喜歡觀球!
# 字典
print('{name}的女朋友是{gf},我也喜歡{gf}!'.format(**{'name':'鋼鐵俠','gf':'小辣椒'}))
# 鋼鐵俠的女朋友是小辣椒,我也喜歡小辣椒!
# 元組+字典
print('我是{beauty}的{1},我們都喜歡{0},請大家{2}!'\
      .format(*('球類','球迷','文明觀球'),**{'beauty':'斯嘉麗約翰遜',}))
# 我是斯嘉麗約翰遜的球迷,我們都喜歡球類,請大家文明觀球!
# 位置參數(shù)、關(guān)鍵字參數(shù)、元組、字典混合使用:
print('我是{name},好像{age}了 ^_^,在{0},等你哦!\n喜歡{1}、{2}和{3}。\n我的唯一 >>>:{only_one}\n我的小可愛 >>>: {love}!'\
      .format('武漢',name='蘇光體',age=18,*('讀書','健身','折騰數(shù)碼'),**{'only_one':'楊林','love':'蘇弘睿'}))
# 我是蘇光體,好像18了 ^_^,在武漢,等你哦!
# 喜歡讀書、健身和折騰數(shù)碼。
# 我的唯一 >>>:楊林
# 我的小可愛 >>>: 蘇弘睿!

使用元組或者字典格式化輸出的形式就是相當(dāng)于將元組和字典打散,變成位置參數(shù)們和關(guān)鍵字參數(shù)們?nèi)缓蟀凑涨懊娴姆椒▊鲄⒕托小?/p>

3、對象參數(shù)格式化輸出傳值:

formate還可以使用對象屬性傳參,這個對象可以是實例化的對象,也可以是列表、字典。

# 對象屬性傳參
# 實例化對象:
class Dog:
    def __init__(self,name,speak):
        self.name=name
        self.speak=speak
dog1=Dog('小黃','汪汪汪')
print('我的{0.name}會{0.speak}。'.format(dog1))
# 我的小黃會汪汪汪。
# 文件對象
with open('text.txt','wb') as f:
    print('打開的文件名為:{0.name}'.format(f))
# 打開的文件名為:text.txt
# 列表、字典對象
print('I have a {0[0]} , I have a {0[1]} .'.format(['Apple','Pen']))
print('我叫{0[name]},{0[id]}就是我!'.format({'name':'阿星','id':'9527'}))
print('{1[name]}變成了{(lán)0[0]},藏進(jìn)了{(lán)1[role]}的褲襠里,為什么不變{0[1]}而是{0[0]}呢?'.format(['葡萄','蘋果'],{'name':'菩提老祖','role':'至尊寶'}))
# I have a Apple , I have a Pen .
# 我叫阿星,9527就是我!
# 菩提老祖變成了葡萄,藏進(jìn)了至尊寶的褲襠里,為什么不變蘋果而是葡萄呢?

4、格式說明符:規(guī)定傳入?yún)?shù)字符的格式

比如:

print('{0:.4f}'.format(3.1415926))
#在傳入?yún)?shù)后面用冒號:寫入規(guī)定的格式:.4f(取4位小數(shù)) 結(jié)果為:3.1416

說明符格式標(biāo)準(zhǔn):[填充]對齊方式][正負(fù)號][#][0][寬度][分組選項][.精度][類型碼]   同時存在是有順序之分的,具體使用下面有具體示例:

填充:

(1)填充字符只能有一個

(2)不指定默認(rèn)用空格填充

(3)如果指定填充字符,則必須要同時指定對齊方式

對齊方式:

(1)<    左對齊

(2)>    右對齊

(3)^    居中對齊

(4)=    在正負(fù)號和數(shù)字之間填充(僅對數(shù)字類型有效)可以輸出類似:+00000012的字符串。

正負(fù)號:

(1)僅對數(shù)字類型生效

(2)+ - 正負(fù)號

(3)空格:正數(shù)前面需要添加一個空格,以便與負(fù)數(shù)對齊

寬度width

(1)不指定寬度,寬度由內(nèi)容決定

(2)寬度前有0,意味著用0填充,等價于 0=的填充和對齊方式

精度

(1)指小數(shù)點后面展示的小數(shù)位數(shù)。

(2)對于非數(shù)字類型,指最大字段寬度。

(3)整數(shù)類型不能指定精度,會報錯的。

下面看示例吧:

#在傳入?yún)?shù)后面用冒號:寫入規(guī)定的格式:.4f(取4位小數(shù)) 結(jié)果為:3.1416
# 填充、對齊、寬度
print('{0:人>2}'.format('<我是誰>'))   # 寬度不夠,按實際字符顯示
print('{0:人<11}'.format('<我>'))
print('{0:人^11}'.format('<我>'))
# <我是誰>
# <我>人人人人人人人人
# 人人人人<我>人人人人
# 正負(fù)號、精度
print('{0:*=+10.4f}'.format(3.1415926))  # '*'>填充符,'='>指定在正負(fù)號和數(shù)字之間填充,'10'>寬度,'.4f'>精度
print('{0:*>+10.4f}'.format(3.1415926))  # 同上,'>'>右對齊
# +***3.1416
# ***+3.1416
print('{0:&>10.4f}'.format(3.1415926))
print('{0:&<10.4f}'.format(3.1415926))
print('{0:&>10.4}'.format('我是中國人'))  # 精度為4,去字符串中的前4個字符
# &&&&3.1416
# 3.1416&&&&
# &&&&&&我是中國

類型碼(規(guī)定輸出的數(shù)據(jù)類型)

(1)字符串類型

(2)整數(shù)類型

(3)浮點數(shù)類型

# 字符串類型(默認(rèn)類型,忽視)
print('{0:s}'.format('abc'))    # abc
print('{0:}'.format('abc'))     # abc
# 整數(shù)類型
# b 二進(jìn)制|c Unicode字符|d 十進(jìn)制整數(shù)|還有很多比如o八進(jìn)制|x十六進(jìn)制...等等
print('{0:b}'.format(101))     # 1100101
print('{0:c}'.format(101))     # e
print('{0:d}'.format(666))     # 666
# 浮點數(shù)字類型
# e 科學(xué)計數(shù)(默認(rèn)精度6位)
print('{0:e}'.format(31415926))   # 3.141593e+07
# f 定點記法(默認(rèn)精度6位)
print('{0:f}'.format(3.1415926))   # 3.141593

以上例子可以說不太全面,只是大概舉了幾個常見的,除了e,f類型還有g(shù)通用類型,n number類型,對于日常使用的話并不常用。所以不一一列出。

5、其他補充:

花括號本事如需格式化輸出,可以用外套2層花括號轉(zhuǎn)義解決

print('{{0}}'.format('abc'))       # {0}
print('{{{0}}}'.format('abc'))     # {abc}

一些另類格式化輸出:

from datetime import datetime
print('今天是:{0:%Y-%m %H:%M}'.format(datetime.now()))
# 結(jié)果:
今天是:2019-05 15:10

總結(jié):

str.format()格式化輸出方法可以說是%s的加強型,特別是在處理更復(fù)雜的格式化輸出過程時候,可以更精確的進(jìn)行達(dá)到輸出目的,它集成的方法可以說比較繁雜,很多方法個人認(rèn)為用處不大,僅僅是錦上添花的作用,個人認(rèn)為只要掌握前面幾個簡單的位置參數(shù)、關(guān)鍵字參數(shù)、元組、字典的傳參形式的格式化輸出就可以了。后面的方法可以有,但是不建議進(jìn)行強行記憶,因為精力有限,用時再打開翻翻也就明了。

上述就是小編為大家分享的Python中如何使用str.format方法了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI