首页 > 编程语言 >我的Python程序太慢了。如何加快速度?

我的Python程序太慢了。如何加快速度?

时间:2023-01-19 14:45:54浏览次数:52  
标签:upper 开销 Python newlist 字符串 append time 加快速度 太慢

如果你的Python程序太慢,你可以按照下面给出的提示和技巧 -

抽象化

避免过度抽象,尤其是在微小函数或方法的形式下。抽象往往会产生间接性,并迫使解释器工作更多。如果间接寻址的级别超过完成的有用工作量,则程序将变慢

避免循环开销

如果循环的主体很简单,则 for 循环本身的解释器开销可能是大量的开销。这是地图功能以更好的方式工作的地方。唯一的限制是 map 的循环体必须是函数调用。

让我们看一个循环的例子


newlist = [] for word in oldlist: newlist.append(word.upper())

我们可以改用 map 来避免上述循环的开销 -

newlist = map(str.upper, oldlist)

使用列表理解

列表理解的使用比 for 循环使用更少的开销 让我们看看使用列表理解实现的相同示例 -

newlist = [s.upper() for s in oldlist]

生成器表达式

生成器表达式是在 Python 2.4 中引入的。这些被认为是循环的最佳替代方法,因为它避免了一次生成整个列表的开销。相反,它们返回一个生成器对象,可以逐位迭代 -

iterator = (s.upper() for s in oldlist)

局部变量

Python 访问局部变量的效率比全局变量高得多。我们可以使用局部变量本身来实现上面的例子 -


def func(): upper = str.upper newlist = [] append = newlist.append for word in oldlist: append(upper(word)) return newlist

导入语句开销

导入语句可以轻松执行。将它们放在函数中以限制其可见性和/或减少初始启动时间通常很有用。在某些情况下,重复执行导入语句会严重影响性能。

连接字符串

使用 Join 连接许多字符串时,这是一个更好、更快的选择。但是,当字符串不多时,使用 + 运算符进行串联会更有效。执行时间更短。让我们用两个例子来了解这一点——

使用 + 运算符连接多个字符串

我们现在将连接许多字符串并使用时间模块检查执行时间 -


from time import time myStr ='' a='gjhbxjshbxlasijxkashxvxkahsgxvashxvasxhbasxjhbsxjsabxkjasjbxajshxbsajhxbsajxhbasjxhbsaxjash' l=[] # Using the + operator t=time() for i in range(1000): myStr = myStr+a+repr(i) print(time()-t)

输出

0.003464221954345703

使用联接连接多个字符串

我们现在将使用 Join 连接许多字符串并检查执行时间。当我们有很多字符串时,连接是一个更好、更快的选择 -


from time import time myStr ='' a='gjhbxjshbxlasijxkashxvxkahsgxvashxvasxhbasxjhbsxjsabxkjasjbxajshxbsajhxbsajxhbasjxhbsaxjash' l=[] # Using the + operator t=time() for i in range(1000): l.append(a + repr(i)) z = ''.join(l) print(time()-t)

输出

0.000995635986328125

标签:upper,开销,Python,newlist,字符串,append,time,加快速度,太慢
From: https://www.cnblogs.com/10zhan/p/17061437.html

相关文章

  • (转载)Python中关键词yield怎么用?
    原文:https://stackoverflow.com/questions/231767/what-does-the-yield-keyword-do译文:https://zhuanlan.zhihu.com/p/23276711?refer=passer问题描述:Python中关......
  • Python如何运行程序
    Python如何运行程序Python解释器简介解释器是一种让其他程序运行起来的程序。Python解释器将读取程序,并按照其中的命令执行,得出结果。解释器是代码与机器的计算机硬件......
  • win10下python3.9的代理报错问题解决(附web3的polygon爬虫源码)
    背景因为工作中经常需要代理访问,而开了代理,request就会报错SSLError,如下:requests.exceptions.SSLError:HTTPSConnectionPool(host='test-admin.xxx.cn',port=443):Ma......
  • python3安装
    前言由于CentOS7本身就需要安装Python2.7.5,而且这个Python2不能被删除,因为有很多系统命令,比如yum都要用到。whichpythonPython3的方法首先安装依赖包yum-ygroupi......
  • python提取json中键值
    0X00 样例数据:{'d':{'__type':'st','YX':"<tableid='tabyxlist'><tr><tdclass='tdth'>院校名称</td><tdclass='tdth'>计划数</td></tr><trid=......
  • 【转载】 python鸭子类型与protocol
    版权声明:本文为CSDN博主「yuanzhoulvpi」的原创文章,遵循CC4.0BY-SA版权协议,转载请附上原文出处链接及本声明。原文链接:https://blog.csdn.net/yuanzhoulvpi/article/deta......
  • python _XMLParser.__init__()初始化失败,提示“takes 1 positional argument but 4 we
    问题:在一个新的环境下,执行openpyxl相关的操作,初始化时,逐步执行,需要调到 ElementTree.py_XMLParser.__init__(self,html,target,encoding),但是初始化报错,【 _XMLPars......
  • [oeasy]python0053_ 续行符_line_continuation_python行尾续行
    续行符与三引号回忆上次内容上次还是转义序列类型英文符号\abell响铃\bbackspace退格\ttab水平制表符\vverticaltab垂直制表符换行不......
  • 一种基于 Python 的 Pscad 仿真数据处理方案
    起因在使用PsCad进行仿真的过程中,常常需要记录数据。PsCad会默认将仿真数据存储为.out文件和.inf文件。然而,这样的数据文件并不能直接导入到Python或者Matlab......
  • python基础: 垃圾回收机制、字符编码、文件操作
    目录垃圾回收机制引用计数标记清除分代回收字符编码简介发展史字符编码的实操文件操作垃圾回收机制说明:我们在编写代码的时候涉及到存储空间的申请和存储空间的释放的操......