很多人抱怨说自己写的Python代码跑的慢,尤其是当处理的数据集比较大的时候,其实稍微改动几行代码就可以让你的代码性能提高好几倍,不信一起来看下面这个5个小技巧。

1.for 循环

我们大部分的时候代码里面都有for循环,然后里面嵌套一段逻辑处理,下面有两种方法来完成:

ironpython运行速度 python代码运行速度_python


二者的性能差距有多大呢,一般我们用内置的timeit模块来量化比较:

ironpython运行速度 python代码运行速度_python_02


把传统的for改成推导列表,高下立判,性能提高了很多,提升了200%

2.用set而不用list

我们再来看一个常见的场景,搜索性能的时候用set是列表10倍,不信看下面这个例子

ironpython运行速度 python代码运行速度_python_03


原因搜索成员的时候,Python的set比list快很多。差距就在if i in mylist 和if i in myset。列表的复杂度是O(n),而集和的复杂度是O(1),搜索起来肯定是set快!

3.交换if和for的位置

很多时候,我们是在for循环内部进行条件判断,循环一个变量,然后用if/else进行判断。对于这样的情况,可以优化一下,把if/else提到for循环外边,也可以提高性能。

ironpython运行速度 python代码运行速度_Python_04

4.巧妙的用try/except语句

很多时候在一个for循环内部,对i进行计算,然后添加到一个list里面,如果能巧妙地利用try/except,可以摆脱对if/else检查的开销,从而提高性能。

ironpython运行速度 python代码运行速度_搜索_05

5.神器collection模块

collection库提供了很多模块,这些模块非常有用,有一些模块是跟容器有关,大部分的实战项目我们都会用到。比如deque双向队列和defaultdict缺省字典。

1).双向队列deque

ironpython运行速度 python代码运行速度_for循环_06


deque是双向队列,如果你的业务逻辑里面需要大量的从队列的头或者尾部删除,添加,用deque的性能会大幅提高!如果只是小队列,并且对元素需要随机访问操作,那么list会快一些。

2).缺省字典defaultdict

对于字典的使用,我们要学会用defaultdict来代替,一来是因为有缺省值非常安全,如果访问不存在的key,不会报错;二来是Pyhon性能会大幅提高。

ironpython运行速度 python代码运行速度_for循环_07


仅仅换了字典数据结构,性能就大幅的提高了3倍。

Python里面的技巧还是很多的,尤其是性能优化这块,Py3已经比Py2性能上高了许多,如果我们在平时写代码的时候,能多一份思考,代码不仅能work还能提升性能,相信你经常这样思考,慢慢的就会成为高手啦!