目錄
1、來自c語言的%方式
2、format()拼接方式
3、() 類似元組方式
4、物件導向模板拼接
5、常用的+號方式
6、join()拼接方式
7、f-string方式
這篇文章主要給大家總結介紹了關於python拼接字串的7種方法,分別是來自c語言的%方式、format()拼接方式、() 類似元組方式、物件導向模板拼接、join()拼接方式以及f-string方式,文中通過示例**介紹的非常詳細,需要的朋友可以參考下
在python中,我們經常會遇到字串的拼接問題,幾乎任何一種程式語言,都把字串列為最基礎和不可或缺的資料型別。而拼接字串是必備的一種技能。
#字串拼接——佔位符
print('%s,%s'%('hello','word'))
#字串拼接——整數
print('%d'%5)
#字串拼接——浮點數
print("%f"%2.5)
#字串拼接——十六進製制
print("%x"%16)
%號格式化字串的方式繼承自古老的c語言,這在很多程式語言都有類似的實現。上例的%s是乙個佔位符,它僅代表一段字串,並不是拼接的實際內容。實際的拼接內容在乙個單獨的%號後面,放在乙個元組裡。
類似的佔位符還有:%d(代表乙個整數)、%f(代表乙個浮點數)、%x(代表乙個16進製制數),等等。%佔位符既是這種拼接方式的特點,同時也是其限制,因為每種佔位符都有特定意義,實際使用起來太麻煩了。
#{}拼接簡潔版
print("hello {},my name is {}".format('python','邏得島'))
#{}拼接對號入座版
print("hello ,my name is ".format("python","邏得島"))
print("hello ,my name is ".format(name1 = "python",name2 = "邏得島"))
這種方式使用花括號{}做佔位符,在format方法中再轉入實際的拼接值。容易看出,它實際上是對%號拼接方式的改進。這種方式在python2.6中開始引入。
上例中,簡潔版的花括號中無內容,缺點是容易弄錯次序。對號入座版主要有兩種,一種傳入序列號,一種則使用key-value的方式。實戰中,我們更推薦後一種,既不會數錯次序,又更直觀可讀。
#()類似元組方式
word1 = ("hello"," ","python")
word2 = ("hello" " " "python")
print(word1)
print(word2)
這種方式看起來很快捷,但是,括號()內要求元素是真實字串,不能混用變數,所以不夠靈活。注意,上例中word2並不是乙個元組,因為元素間沒有逗號分隔符,這些元素間可以用空格間隔,也可以不要空格。使用type()檢視,發現它就是乙個str型別。
# 多元素時
word3 = 'hello'
word4 = (word3,'world')
print(word3)
print(word4)
#物件導向模板拼接
from string import template
s = template("$ $")
print(s.safe_substitute(s1 = "hello",s2 = "python"))
#使用+號拼接
print("使用+拼接:")
s1 = "hello python."
s2 = "my name is 邏得島"
print(s1 + s2)
這種方式最常用、直觀、易懂,是入門級的實現方式。但是,它也存在兩處讓人容易犯錯的地方。
首先,新入門程式設計的同學容易犯錯,他們不知道字串是不可變型別,新的字串會獨佔一塊新的記憶體,而原來的字串保持不變。上例中,拼接前有兩段字串,拼接後實際有三段字串。
其次,一些有經驗的老程式設計師也容易犯錯,他們以為當拼接次數不超過3時,使用+號連線符就會比其它方式快(ps:不少python教程都是如此建議),但這沒有任何合理根據。
事實上,在拼接短的字面值時,由於python中的 常數摺疊 (constant folding)功能,這些字面值會被轉換成更短的形式,例如'a'+'b'+'c' 被轉換成'abc','hello'+'world'也會被轉換成'hello world'。這種轉換是在編譯期完成的,而到了執行期時就不會再發生任何拼接操作,因此會加快整體計算的速度。
常數摺疊優化有乙個限度,它要求拼接結果的長度不超過20。所以,當拼接的最終字串長度不超過20時,+號操作符的方式,會比後面提到的join等方式快得多,這與+號的使用次數無關。
題外話:你是否覺得20這個數字很熟悉呢?沒錯,字串類的特權種族也是以20為限。
#join拼接
list = ["hello","邏得島"]
join1 = ",".join(list)
join2 = '-'.join(list)
print(join1)
print(join2)
str物件自帶的join()方法,接受乙個序列引數,可以實現拼接。拼接時,元素若不是字串,需要先轉換一下。可以看出,這種方法比較適用於連線序列物件中(例如列表)的元素,並設定統一的間隔符。
當拼接長度超過20時,這種方式基本上是首選。不過,它的缺點就是,不適合進行零散片段的、不處於序列集合的元素拼接。
#7、f-string方式
name = "python"
myname = "邏得島"
words = f"hello . my name is "
print(words)
f-string方式出自pep 498(literal string interpolation,字面字串插值),從python3.6版本引入。其特點是在字串前加 f 標識,字串中間則用花括號{}包裹其它字串變數。
這種方式在可讀性上秒殺format()方式,處理長字串的拼接時,速度與join()方法相當。
儘管如此,這種方式與其它某些程式語言相比,還是欠優雅,因為它引入了乙個 f 標識。而其它某些程式語言可以更簡練,比如shell:
name="world"
myname="python_cat"
words="hello $. my name is $."
echo $words>>>hello world. my name is python_cat.
總結一下,我們前面說的「字串拼接」,其實是從結果上理解。若從實現原理上劃分的話,我們可以將這些方法劃分出三種型別:
格式化類:%、format()、template當要處理字串列表等序列結構時,採用join()方式;拼接長度不超過20時,選用+號操作符方式;長度超過20的情況,高版本選用f-string,低版本時看情況使用format()或join()方式。拼接類:+、()、join()
插值類:f-string
Python 字串拼接方法總結
1 str1 str2 我想大多數人都會使用 號來進行字串的拼接 eg wbz ctt wbzctt 2 str1,str2 這種方式就有點特殊了,如果兩個字串用逗號隔開,那仫這兩個字串就會被拼接,但是拼接之後的新的字串中間會存在空格 eg wbz ctt wbz ctt 3 str1 str2 這...
字串拼接總結
常用的字串拼接方式有五種,分別是使用 使用concat 使用stringbuilder 使用stringbuffer以及使用stringutils.join。由於字串拼接過程中會建立新的物件,所以如果要在乙個迴圈體中進行字串拼接,就要考慮記憶體問題和效率問題。因此,經過對比,我們發現,直接使用str...
python 字串拼接
閱讀目錄 1.加號 2.逗號 3.直接連線 4.格式化 5.join 6.多行字串拼接 回到頂部 示例版本為py2 回到頂部 第一種,有程式設計經驗的人,估計都知道很多語言裡面是用加號連線兩個字串,python裡面也是如此直接用 來連線兩個字串 print python tab 結果 pythont...