標籤:
現有一文本,每行一條資料,實現這行資料中有所要關鍵字則打出這行
import syswith open(sys.argv[1]) as alls:alls2 = [_.strip() for _ in alls]for _ in alls2:if sys.argv[2] in _:print _
一開始我是這麼寫的,後來覺得既不美觀,速度又慢(運行花了2.31 s),進行了改寫
with open( sys.argv[1] ) as alls:results = [ _.strip() for _ in alls if sys.argv[2] in _.strip() ]print '\n'.join( results )
運行耗時1.54 s,快了34%,效果不錯
<pre name="code" class="python">with open( sys.argv[1] ) as alls:results = [ _.strip() for _ in alls if sys.argv[2] in _.strip() ]
for result in results:print result
print '\n'.join( results )
打出時太快,沒有瀑布的感覺,改成
for result in results:print result
已耗用時間1.59 s居然慢了
後來用map函數改寫
def fetch( _ ):_2 = _.strip()global searchPif searchP in _2:pass#print _2
map( fetch, list)
居然更慢了,耗時2 s
用上虛擬函數吧
x = map( lambda _: _.strip() if searchP in _.strip() else None, alls )
噩夢啊,更慢了 2.1 s
最後兼顧美觀與速度,用了filter函數
xs = filter( lambda _: True if searchP in _.strip() else False, alls )for x in xs:if x:print x,
耗時1.67 s,雖然還沒傳統的快,但技巧性已經提高了,效率就先放下吧。
著作權聲明:本文為博主原創文章,未經博主允許不得轉載。
【python】尋找字串時哪一種寫法出結果速度更快?