Python性能调优的小技巧有哪些
发表于:2025-02-19 作者:千家信息网编辑
千家信息网最后更新 2025年02月19日,这篇文章主要为大家展示了"Python性能调优的小技巧有哪些",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"Python性能调优的小技巧有哪些"这篇文章吧。
千家信息网最后更新 2025年02月19日Python性能调优的小技巧有哪些
这篇文章主要为大家展示了"Python性能调优的小技巧有哪些",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"Python性能调优的小技巧有哪些"这篇文章吧。
1 多多使用列表生成式
替换下面代码:
cube_numbers = [] for n in range(0,10): if n % 2 == 1: cube_numbers.append(n**3)
为列表生成式写法:
cube_numbers = [n**3 for n in range(1,10) if n%2 == 1]
2 内置函数
尽可能多使用下面这些内置函数:
3 尽可能使用生成器
单机处理较大数据量时,生成器往往很有用,因为它是分小片逐次读取,最大程度节省内存,如下网页爬取时使用yield
import requestsimport redef get_pages(link): pages_to_visit = [] pages_to_visit.append(link) pattern = re.compile('https?') while pages_to_visit: current_page = pages_to_visit.pop(0) page = requests.get(current_page) for url in re.findall('', str(page.content)): if url[0] == '/': url = current_page + url[1:] if pattern.match(url): pages_to_visit.append(url) # yield yield current_pagewebpage = get_pages('http://www.example.com')for result in webpage: print(result)
4 判断成员所属关系最快的方法使用 in
for name in member_list: print('{} is a member'.format(name))
5 使用集合求交集
替换下面代码:
a = [1,2,3,4,5]b = [2,3,4,5,6]overlaps = []for x in a: for y in b: if x==y: overlaps.append(x)print(overlaps)
修改为set和求交集:
a = [1,2,3,4,5]b = [2,3,4,5,6]overlaps = set(a) & set(b)print(overlaps)
6 多重赋值
Python支持多重赋值的风格,要多多使用
first_name, last_name, city = "Kevin", "Cunningham", "Brighton"
7 尽量少用全局变量
Python查找最快、效率最高的是局部变量,查找全局变量相对变慢很多,因此多用局部变量,少用全局变量。
8 高效的itertools模块
itertools模块支持多个迭代器的操作,提供最节省内存的写法,因此要多多使用,如下求三个元素的全排列:
import itertoolsiter = itertools.permutations(["Alice", "Bob", "Carol"])list(iter)
9 lru_cache 缓存
位于functools模块的lru_cache
装饰器提供了缓存功能,如下结合它和递归求解斐波那契数列第n:
import functools@functools.lru_cache(maxsize=128)def fibonacci(n): if n == 0: return 0 elif n == 1: return 1 return fibonacci(n - 1) + fibonacci(n-2)
因此,下面的递归写法非常低效,存在重复求解多个子问题的情况:
def fibonacci(n): if n == 0: # There is no 0'th number return 0 elif n == 1: # We define the first number as 1 return 1 return fibonacci(n - 1) + fibonacci(n-2)
10 内置函数、key和itemgetter
上面提到尽量多使用内置函数,如下对列表排序使用key
,operator.itemgetter
:
import operatormy_list = [("Josh", "Grobin", "Singer"), ("Marco", "Polo", "General"), ("Ada", "Lovelace", "Scientist")]my_list.sort(key=operator.itemgetter(0))my_list
以上是"Python性能调优的小技巧有哪些"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
变量
函数
生成
性能
技巧
全局
内容
写法
模块
篇文章
最快
交集
代码
内存
多个
尽可能
局部
生成器
缓存
递归
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
全面加强网络安全防护水平
数据库的数据检索出来规定格式
数字货币和网络安全
数据库并行处理技术研究
抽奖视频服务器
硚口软件开发价格
互联网软件科技
hcl网络安全
思科网络技术学院网络基础
java数据库为什么同步
mysql实现跨服务器复制表
卡卡网络技术有限公司好不好
软件开发框架和语言
手机版本不同的服务器怎么下载
未转变者进入服务器
腾讯云服务器场景类型
excel服务器应用
wps引入外部数据库
数据库系统体系结构映像
防范网络安全会议记录内容
拨打电信号码提示服务器错误
网络安全教育打击传销征文
合肥哪里有做app软件开发
APP软件开发需要什么步骤
厦门车主互联网络科技
首家网络技术服务中心
深圳携客互联网科技
饿了么的数据库
哪些企业服务器放在贵州云主机
国防科大网络安全专家