文章作者:Tyan
博客:noahsnail.com ?|? CSDN ?|? 簡書
Python使用非常方便、靈活鞋屈,因此很受歡迎范咨。但正因為如此,導(dǎo)致實現(xiàn)同一功能時厂庇,Python代碼有很多寫法渠啊,但不同的寫法有不同的性能。因此寫Python代碼要有良好的習(xí)慣权旷,多寫高性能的代碼替蛉。作者原來平常寫Python代碼也很隨意,直到某天處理大量數(shù)據(jù)時半天看不到結(jié)果拄氯,究其原因躲查,是Python代碼的性能問題導(dǎo)致的。
1. 列表解析與列表重建
#!/usr/bin/env python
# _*_ coding: utf-8 _*_
import time
fr = open('words.txt')
t1 = time.time()
word_list = fr.readlines()
t2 = time.time()
print 'read file time: ', t2 -t1
fr.close()
# for循環(huán)構(gòu)建列表
keywords = []
t1 = time.time()
for word in word_list:
word = word.strip()
keywords.append(word)
t2 = time.time()
print 'for loop time: ', t2 - t1
# 列表解析
t3 = time.time()
keywords = [word.strip() for word in word_list]
t4 = time.time()
print 'list pars time: ', t4 - t3
fr = open('words.txt')
t5 = time.time()
keywords = [word.strip() for word in fr.readlines()]
t6 = time.time()
fr.close()
print 'read file and list parse time: ', t6 - t5
print 'list length: ', len(word_list)
運(yùn)行結(jié)果:
read file time: 0.0318450927734
for loop time: 0.137716054916
list pars time: 0.0910630226135
read file and list parse time: 0.124923944473
list length: 441669
結(jié)論:本次測試中译柏,列表解析時間是for循環(huán)時間的2/3
镣煮。
2. 字符串拼接
#!/usr/bin/env python
# _*_ coding: utf-8 _*_
import time
fr = open('words.txt')
keywords = [word.strip() for word in fr.readlines()]
fr.close()
# 加號拼接字符串
t1 = time.time()
str1 = ''
for word in keywords:
str1 += word
t2 = time.time()
print 'string concat time: ', t2 - t1
# join拼接字符串
t1 = time.time()
str2 = ''.join(keywords)
t2 = time.time()
print 'string join time: ', t2 - t1
print 'list length: ', len(keywords)
運(yùn)行結(jié)果:
string concat time: 0.0814869403839
string join time: 0.0123951435089
list length: 441669
結(jié)論:本次測試中,join
函數(shù)拼接字符串比+=
拼接字符串快6倍多
鄙麦。
3. range與xrange
- range
python中range會直接生成一個list對象典唇。
- xrange
用法與range完全相同,所不同的是生成的不是一個數(shù)組胯府,而是一個生成器介衔,它的類型為xrange
。在生成非常大的數(shù)字序列時盟劫,xrange不會馬上開辟很大的一塊內(nèi)存空間夜牡。如果不是需要返回列表与纽,則盡可能使用xrange
侣签。
測試代碼:
#!/usr/bin/env python
# _*_ coding: utf-8 _*_
import time
t1 = time.time()
for i in range(1000000):
pass
t2 = time.time()
print 'range time: ', t2 -t1
t1 = time.time()
for i in xrange(1000000):
pass
t2 = time.time()
print 'xrange time: ', t2 -t1
測試結(jié)果:
range time: 0.0680990219116
xrange time: 0.0329170227051
結(jié)論:本次測試中塘装,xrange
比range
快一倍多。