python性能优化

1。去除不必要的显式for循环,使用向量化计算。

复制代码
 1 import time
 2 import numpy as np
 3 
 4 
 5 def for_time():
 6     """Make a array, len = 1000000, use for loop add one."""
 7     start = time.time()
 8     list_data = np.arange(0, 10000000, 1)
 9     for i in range(1000000):
10         list_data[i] += 1
11     print 'for loop used time: ', time.time() - start
12 
13 
14 def vector_time():
15     """make a array, use vector calculation add one."""
16     start = time.time()
17     list_data = np.arange(0, 10000000, 1)
18     list_data += 1
19     print 'vector calculation used time: ', time.time() - start
20 
21 
22 if __name__ == '__main__':
23     for_time()
24     vector_time()
复制代码

for loop used time:  0.359999895096
vector calculation used time:  0.0160000324249

 

2. 使用多进程,开核。

复制代码
1 import multiprocessing
2 
3 
4 def use_pool(func, args):
5     pool = multiprocessing.Pool(processes=2)
6     res = pool.map(func, args)
7     pool.close()
8     pool.join()
9     return res
复制代码

3.使用sklearn.extenals.joblib 扩展库

1 from sklearn.externals.joblib import Parallel, delayed
2 
3 
4 def parallel(func, arg):
5     Parallel(-1)(delayed(func)(i) for i in arg)

4. 使用bottleneck库。

该库基于Cpython实现,着眼于高性能。

posted @   有虫子啊  阅读(1144)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
历史上的今天:
2017-10-21 python 字符串、列表、字典相关内建方法
点击右上角即可分享
微信分享提示