让你python代码更快的3个小技巧

https://mp.weixin.qq.com/s/RwqgT0gWM4IZ2NTlyl2_Hg

一、函数

函数可以提高代码的可读性,那么用了函数对程序的执行效率是否有影响呢?我们来做个对比实验。

先来看一个不用函数的版本:

import math
import time

start = time.time()    # 开始计时
lst = []    # 定义一个空列表
for i in range(1, 10000000):
    lst.append(math.sqrt(i))    # 疯狂地往列表里添加计算结果
end = time.time()    # 停止计时
print(end-start)

此代码在我的电脑上输出为 2.124(不同配置的电脑结果不一样,可多次运行取平均值)。再来加上函数试一下:

import math
import time

def func():
    lst = []   # 定义一个空列表
    for i in range(1, 10000000):
        lst.append(math.sqrt(i))   # 疯狂地往列表里添加计算结果
    return lst   # 返回结果

start = time.time()   # 开始计时
lst = func()   
end = time.time()   # 停止计时
print(end-start)

在我的电脑上,使用了函数的程序用了大概花了 1.743 秒。多次尝试,基本上都会比上一个版本节省 15~20% 左右时间,这个差距还是存在的。

有人可能会觉得,增加了函数调用,效率可能会低。但实际上,我们这里只是增加了一次调用,影响甚微。而由于 Python 中局部变量和全局变量的实现方式不同,使用局部变量效率会高些。

所以使用函数不仅提高可读性,用得好还能让代码运行得更快。

二、去掉属性访问

再来看另一个例子,还是刚才的函数版本,我们做一点修改,改变其中导入函数的方式,由 math.sqrt 改为 sqrt:

from math import sqrt   # 直接引用特定函数或属性
import time

def func():
    lst = []
    for i in range(1, 10000000):
        lst.append(sqrt(i))    # 直接调用 sqrt
    return lst

start = time.time()
lst = func()
end = time.time()
print(end-start)

在其它代码均没有变动的情况下,这个程序的输出时间变成了……

1.413 秒!

居然更快了。这又是为什么呢?

因为在进行属性访问的时候啊,会调用这个对象的 getattribute 或者 getattr 方法,造成了额外的开销,所以导致速度变慢。

三、列表推导式

最后再来看看列表推导式(List Comprehension),它的效率和普通 for 循环会有不一样吗?
继续在上一个版本上修改:

from math import sqrt
import time

def func():
    # for 循环改为列表推导式
    lst = [sqrt(i) for i in range(1, 10000000)]
    return lst

start = time.time()
lst = func()
end = time.time()
print(end-start)

结果是 0.968 秒!

这又是为什么呢?因为列表推导式内的迭代是 C 实现的,所以效率更高。

同最初的版本相比,实现同样的效果,我们仅通过调整代码的写法,速度就提高了一倍还多。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值