共计 1474 个字符,预计需要花费 4 分钟才能阅读完成。
导读 | 今天总结三个提升 Python 运行速度的方法,只从代码本身考虑,提升运行速度并不会从编写 C 扩展的代码、基于 JIT 的编译器技术考虑。 |
今天总结三个提升 Python 运行速度的方法,只从代码本身考虑,提升运行速度并不会从编写 C 扩展的代码、基于 JIT 的编译器技术考虑。
关于代码执行效率的第一个方法是减少频繁的方法访问,尤其是在多层循环内层、且循环次数较多的操作,差距尤为明显。
# 真是模块内全局变量
import math
def compute_sqrt(nums):
result = []
for n in nums: # 假如 nums 长度很大
# 1. math.sqrt 会被频繁访问
# 2. result.append 也会被频繁访问
result.append(math.sqrt(n))
return result
看到在 for 循环里面,涉及 2 个频繁的访问:
math.sqrt 会被频繁访问
result.append 也会被频繁访问
因此第一步做如下更改:直接导入 sqrt,而不是导入整个模块后再去引用 sqrt
# 直接导入 sqrt,而不是导入整个模块后再去引用 sqrt
from math import sqrt
def compute_sqrt(nums):
result = []
for n in nums: # 假如 nums 长度很大
# 1. math.sqrt 会被频繁访问
# 2. result.append 也会被频繁访问
result.append(sqrt(n))
return result
然后再修改 result.append,不用频繁访问 append,使用标签 apd 指向它就行了:
# 直接导入 sqrt,而不是导入整个模块后再去引用 sqrt
from math import sqrt
def compute_sqrt(nums):
result = []
apd = result.append
for n in nums: # 假如 nums 长度很大
# 1. math.sqrt 会被频繁访问
# 2. result.append 也会被频繁访问
apd(sqrt(n))
return result
第二个方法:查找局部变量的效率是最高的!!! 对于频繁访问的变量应尽可能是局部变量,消除不必要的全局变量访问。所以对于上面代码,sqrt 还是模块级别的全局变量,所以修改为:
def compute_sqrt(nums):
# 调整 sqrt 为局部变量
from math import sqrt
result = []
apd = result.append
for n in nums: # 假如 nums 长度很大
# 1. math.sqrt 会被频繁访问
# 2. result.append 也会被频繁访问
apd(sqrt(n))
return result
第三个方法:不要做一些不必要的属性包装。比如 @property 必要时再用,能不用时就别用。如下对于属性 y 做 @property 装饰没有任何意义! 只有在 y 有特定取值,比如只能取大于 0 的非负实数时再用此装饰才有意义。
class A:
def __init__(self, x, y):
self.x = x
self.y = y
@property
def y(self):
return self._y
@y.setter
def y(self, value):
self._y = value
因此修改为下面这样,删去多余的 @property 包装
class A:
def __init__(self, x, y):
self.x = x
self.y = y
以上就是 Python 代码提速的 3 条基本但却容易被忽略的有价值方法,希望对你有用。
正文完
星哥玩云-微信公众号