1.直接透過(+)運算子拼接
>>> 'Hello' + ' ' + 'World' + '!'
'Hello World!'
使用這種方式進行字串連線的操作效率低下,因為python中使用 + 拼接兩個字串時會生成一個新的字串,生成新的字串就需要重新申請記憶體,當拼接字串較多時自然會影響效率。
2.透過str.join()方法拼接
>>> strlist = ['Hello', ' ', 'World', '!']
>>> ''.join(strlist)
'Hello World!'
這種方式一般常使用在將集合轉化為字串,''.join()其中''可以是空字元,也可以是任意其他字元,當是任意其他字元時,集合中字串會被該字元隔開。
3.透過str.format()方法拼接
>>> '{} {}!'.format('Hello', 'World')
'Hello World!'
透過這種方式拼接字串需要注意的是字串中{}的數量要和format方法引數數量一致,否則會報錯。
4.透過(%)運算子拼接
>>> '%s %s!' % ('Hello', 'World')
'Hello World!'
這種方式與str.format()使用方式基本一致。
5.透過()多行拼接
>>> (
... 'Hello'
... ' '
... 'World'
... '!'
... )
'Hello World!'
python遇到未閉合的小括號,自動將多行拼接為一行。
6.透過string模組中的Template物件拼接
>>> from string import Template
>>> s = Template('${s1} ${s2}!')
>>> s.safe_substitute(s1='Hello',s2='World')
'Hello World!'
Template的實現方式是首先透過Template初始化一個字串。這些字串中包含了一個個key。透過呼叫substitute或safe_subsititute,將key值與方法中傳遞過來的引數對應上,從而實現在指定的位置匯入字串。這種方式的好處是不需要擔心引數不一致引發異常,如:
>>> from string import Template
>>> s = Template('${s1} ${s2} ${s3}!')
>>> s.safe_substitute(s1='Hello',s2='World')
'Hello World ${s3}!'
7.透過F-strings拼接
在python3.6.2版本中,PEP 498 提出一種新型字串格式化機制,被稱為“字串插值”或者更常見的一種稱呼是F-strings,F-strings提供了一種明確且方便的方式將python表示式嵌入到字串中來進行格式化:
>>> s1 = 'Hello'
>>> s2 = 'World'
>>> f'{s1} {s2}!'
'Hello World!'
在F-strings中我們也可以執行函式:
#學習中遇到問題沒人解答?小編建立了一個Python學習交流群:153708845
>>> def power(x):
... return x*x
...
>>> x = 5
>>> f'{x} * {x} = {power(x)}'
'5 * 5 = 25'
而且F-strings的執行速度很快,比%-string和str.format()這兩種格式化方法都快得多。