本篇文章主要介紹了python實現字串連接的三種方法及其效率、適用場景詳解,具有一定的參考價值,有興趣的小伙伴們可以參考一下。
python字串連接的方法,一般有以下三種:
方法1:直接透過加號(+)運算子連接
website = 'python' + 'tab' + '.com'
listStr = ['python', 'tab', '.com'] website = ''.join(listStr)
website = '%s%s%s' % ('python', 'tab', '.com')
# -*- coding: utf-8 -*- from time import time def method1(): t = time() for i in xrange(100000): s = 'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab'+'pythontab' print time() - t def method2(): t = time() for i in xrange(100000): s = ''.join(['pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab','pythontab']) print time() -t method1() method2()
# -*- coding: utf-8 -*- from time import time def method1(): t = time() for i in xrange(100000): s = 'pythontab'+'pythontab'+'pythontab'+'pythontab' print time() - t def method2(): t = time() for i in xrange(100000): s = ''.join(['pythontab','pythontab','pythontab','pythontab']) print time() -t method1() method2()
方法3:替換
rrreee
方法效率低
之所以說python 中使用+ 進行字串連接的操作效率低下,是因為python中字串是不可變的類型,使用+ 連接兩個字串時會生成一個新的字串,生成新的字串就需要重新申請內存,當連續相加的字符串很多時(a+b+c+d+e+f+...) ,效率低下就是必然的了
方法2,使用略複雜,但對多個字元進行連接時效率高,只會有一次記憶體的申請。而且如果是對list的字元進行連接的時候,這種方法必須是首選
方法3:字串格式化,這種方法非常常用,本人也推薦使用該方法
下面用實驗來說明字串連接的效率問題。
比較對象:加號連接VS join連接
系統環境:CentOS
實驗一:
0.641695976257
0.341440916061
實驗二:
rrreee
0.0522091388702
結論:加號連接效率低是在連續進行多個字串連接的時候出現的,如果連接的個數較少,加號連接效率反而比join連接效率高