返回顶部
首页 > 资讯 > 后端开发 > Python >python 性能提升的几种方法
  • 135
分享到

python 性能提升的几种方法

几种方法性能python 2022-06-04 18:06:12 135人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

关于python 性能提升的一些方案。 一、函数调用优化(空间跨度,避免访问内存) 程序的优化核心点在于尽量减少操作跨度,包括代码执行时间上的跨度以及内存中空间跨度。 1.大数据求和,使用sum a

关于python 性能提升的一些方案。

一、函数调用优化(空间跨度,避免访问内存)

程序的优化核心点在于尽量减少操作跨度,包括代码执行时间上的跨度以及内存中空间跨度。

1.大数据求和,使用sum


a = range(100000)
%timeit -n 10 sum(a)
10 loops, best of 3: 3.15 ms per loop
%%timeit
  ...: s = 0
  ...: for i in a:
  ...:  s += i
  ...:
100 loops, best of 3: 6.93 ms per loop

2.小数据求和,避免使用sum


%timeit -n 1000 s = a + b + c + d + e + f + g + h + i + j + k # 数据量较小时直接累加更快
1000 loops, best of 3: 571 ns per loop
%timeit -n 1000 s = sum([a,b,c,d,e,f,g,h,i,j,k]) # 小数据量调用 sum 函数,空间效率降低
1000 loops, best of 3: 669 ns per loop

结论:大数据求和sum效率高,小数据求和直接累加效率高。

二、for循环优化之取元素(使用栈或寄存器,避免访问内存)


for lst in [(1, 2, 3), (4, 5, 6)]: # lst 索引需要额外开销
  pass

 应尽量避免使用索引。


for a, b, c in [(1, 2, 3), (4, 5, 6)]: # better
  pass

相当于给每一个元素直接赋值。


def force():
 lst = range(4)
 for a1 in [1, 2]:
   for a2 in lst:
     for a3 in lst:
       for b1 in lst:
         for b2 in lst:
           for b3 in lst:
             for c1 in lst:
               for c2 in lst:
                 for c3 in lst:
                   for d1 in lst:
                     yield (a1, a2, a3, b1, b2, b3, c1, c2, c3, d1)
                      
%%timeit -n 10
for t in force():
  sum([t[0], t[1], t[2], t[3], t[4], t[5], t[6], t[7], t[8], t[9]])
10 loops, best of 3: 465 ms per loop
%%timeit -n 10
for a1, a2, a3, b1, b2, b3, c1, c2, c3, d1 in force():
  sum([a1, a2, a3, b1, b2, b3, c1, c2, c3, d1])
10 loops, best of 3: 360 ms per loop

三、生成器优化(查表代替运算)


def force(start, end): # 用于密码暴力破解程序
  for i in range(start, end):
    now = i
    sublst = []
    for j in range(10):
      sublst.append(i % 10) # 除法运算开销较大,比乘法大
      i //= 10
    sublst.reverse()
    yield(tuple(sublst), now)

def force(): # better
 lst = range(5)
 for a1 in [1]:
   for a2 in lst:
     for a3 in lst:
       for b1 in lst:
         for b2 in lst:
           for b3 in lst:
             for c1 in lst:
               for c2 in lst:
                 for c3 in lst:
                   for d1 in lst:
                     yield (a1, a2, a3, b1, b2, b3, c1, c2, c3, d1)
  

r0 = [1, 2] # 可读性与灵活性
r1 = range(10)
r2 = r3 = r4 = r5 = r6 = r7 = r8 = r9 = r1
force = ((a0, a1, a2, a3, a4, a5, a6, a7, a8, a9)
      for a0 in r0 for a1 in r1 for a2 in r2 for a3 in r3 for a4 in r4
      for a5 in r5 for a6 in r6 for a7 in r7 for a8 in r8 for a9 in r9)

四、幂运算优化(pow(x,y,z)) 


def isprime(n):
  if n & 1 == 0:
    return False
  k, q = find_kq(n)
  a = randint(1, n - 1)
  if pow(a, q, n) == 1: # 比使用 a ** q % n 运算优化数倍
    return True
  for j in range(k):
    if pow(a, pow(2, j) * q, n) == n - 1: # a **((2 ** j) * q) % n
      return True
  return False

结论:pow(x,y,z)优于x**y%z.

五、除法运算优化


In [1]: from random import getrandbits
 
In [2]: x = getrandbits(4096)
 
In [3]: y = getrandbits(2048)
 
In [4]: %timeit -n 10000 q, r = divmod(x, y)
10000 loops, best of 3: 10.7 us per loop
 
In [5]: %timeit -n 10000 q, r = x//y, x % y
10000 loops, best of 3: 21.2 us per loop

结论:divmod优于//和%。

六、优化算法时间复杂度  

算法的时间复杂度对程序的执行效率影响最大,在python中可以选择合适的数据结构来优化时间复杂度,如list和set查找某一个元素的时间复杂度分别是O(n)和O(1)。不同场景有不同的优化方式,总的来说,一般有分治,分支定界、贪心动态规划等思想。

七、合理使用copy和deepcopy  

对于dict和list等数据结构的对象,直接赋值使用的是引用的方式。而有些情况下需要复制整个对象,这时可以使用copy包里的copy和deepcopy,这两个函数的不同之处在于deepcopy是递归复制的。效率不同:


In [23]: import copy
In [24]: %timeit -n 10 copy.copy(a)
10 loops, best of 3: 606 ns per loop
In [25]: %timeit -n 10 copy.deepcopy(a)
10 loops, best of 3: 1.17 us per loop

timeit后面的-n表示运行的次数,后两行对应的是两个timeit的输出,下同。由此可见后者慢一个数量级。

关于copy的一个例子:


>>> lists = [[]] * 3
>>> lists
[[], [], []]
>>> lists[0].append(3)
>>> lists
[[3], [3], [3]]

发生的事情是这样的,[[]]是包含一个空列表的只有一个元素的列表,所以[[]] * 3的所有三个元素都是(指向)这个空列表。修改lists的任何元素都修改这个列表。修改效率高。

八、使用dict或set查找元素

Python 字典和集合都是使用hash表来实现(类似c++标准库unordered_map),查找元素的时间复杂度是O(1)。


In [1]: r = range(10**7)
In [2]: s = set(r) # 占用 588MB 内存
In [3]: d = dict((i, 1) for i in r) # 占用 716MB 内存
In [4]: %timeit -n 10000 (10**7) - 1 in r
10000 loops, best of 3: 291 ns per loop
In [5]: %timeit -n 10000 (10**7) - 1 in s
10000 loops, best of 3: 121 ns per loop
In [6]: %timeit -n 10000 (10**7) - 1 in d
10000 loops, best of 3: 111 ns per loop

结论:set 的内存占用量最小,dict运行时间最短。

九、合理使用(generator)和yield(节省内存)


In [1]: %timeit -n 10 a = (i for i in range(10**7)) # 生成器通常遍历更高效
10 loops, best of 3: 933 ns per loop
In [2]: %timeit -n 10 a = [i for i in range(10**7)]
10 loops, best of 3: 916 ms per loop
In [1]: %timeit -n 10 for x in (i for i in range(10**7)): pass
10 loops, best of 3: 749 ms per loop
In [2]: %timeit -n 10 for x in [i for i in range(10**7)]: pass
10 loops, best of 3: 1.05 s per loop

结论:尽量使用生成器去遍历。

以上就是对python 性能提升的一些方案,后续继续补充,需要的可以看下。

--结束END--

本文标题: python 性能提升的几种方法

本文链接: https://lsjlt.com/news/14465.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • python 性能提升的几种方法
    关于python 性能提升的一些方案。 一、函数调用优化(空间跨度,避免访问内存) 程序的优化核心点在于尽量减少操作跨度,包括代码执行时间上的跨度以及内存中空间跨度。 1.大数据求和,使用sum a...
    99+
    2022-06-04
    几种方法 性能 python
  • Python性能提升的方法有哪些
    本篇内容介绍了“Python性能提升的方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!时序分析优化之前,首先要找到是哪部分代码拖慢了...
    99+
    2023-06-16
  • 提升MySQL性能的方法有哪些
    这篇文章主要介绍“提升MySQL性能的方法有哪些”,在日常操作中,相信很多人在提升MySQL性能的方法有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”提升MySQL性能的...
    99+
    2024-04-02
  • 提升网站性能的关键方法
    网站性能优化的必备策略在如今数字化浪潮的背景下,网站已成为企业和个人在线展示业务的主要途径。然而,随着网站功能和复杂性的不断增加,用户的期望也与日俱增。没有快速加载速度和优秀的用户体验,一个网站很容易失去用户。因此,网站性能的优化变得至关重...
    99+
    2023-12-26
    缓存 压缩 并发
  • 详解PostgreSQL提升批量数据导入性能的n种方法
    关键字:批量数据导入,数据加载,大量插入,加快,提升速度 多元化选择时代,人生里很多事物都是如此,凡事都没有一成不变的方式和方法。不管白猫黑猫,能抓老鼠的就是好猫,适合自己的就是最好...
    99+
    2024-04-02
  • PostgreSQL升级的方法有哪几种
    这篇文章主要介绍“PostgreSQL升级的方法有哪几种”,在日常操作中,相信很多人在PostgreSQL升级的方法有哪几种问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Po...
    99+
    2024-04-02
  • 提升网站性能的重要性与方法论
    网站性能优化的必要性与方法论 随着互联网的发展,网站已成为人们获取信息和进行各类在线交流的主要途径之一。然而,很多网站在面对高访问量和复杂的业务场景时表现不佳,导致用户体验差、页面加载缓慢等问题,影响了用户对网站的满意度和忠诚度...
    99+
    2024-02-03
    网站 性能优化 方法论 前端优化 延迟加载
  • golang函数提升性能的有效方法
    提升 go 函数性能的有效方法包括:内联函数(避免调用栈开销)、启用并发(提高应用程序整体性能)、缓存结果(避免重复计算)、使用切片(提高效率)、优化内存分配(减少分配器和垃圾回收器开销...
    99+
    2024-04-26
    golang 函数性能 垃圾回收器
  • 提升家庭WiFi的几个方法
      用户WiFi密码尽量不要使用简单单词,也不要同一个密码在多个网站使用。以下是笔者整理好的提升增强你家Wi-Fi的几个方法:  1. 将路由器设置为按计划重新启动  如果你是众多人之一,必须经常重启他们的路由器,所以它不会辍学,有一个解决...
    99+
    2023-06-04
  • 排序算法的性能提升方法有哪些
    本篇内容介绍了“排序算法的性能提升方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!冒泡排序这是最简...
    99+
    2024-04-02
  • .NET使用Collections.Pooled提升性能优化的方法
    目录简介Collections.Pooled如何使用性能对比PooledList<T>PooledDictionary<TKey, TValue>Pooled...
    99+
    2024-04-02
  • 提升Flask应用性能的方法:使用Gunicorn
    Gunicorn如何提高Flask应用的性能? 随着互联网的快速发展,Web应用程序的性能对于用户体验和企业竞争力变得越来越重要。在处理高并发请求时,Flask框架默认的开发服务器往往无法满足需求。因此,我们需要使用Gunico...
    99+
    2024-01-17
    Flask gunicorn 性能提高
  • 提升网站性能的五种有效途径
    随着互联网的迅猛发展,网站已成为了人们获取信息、交流和消费的重要渠道。然而,随着网站的发展和用户量的增加,网站性能问题也越来越突出。一个好的网站需要快速响应用户请求,提供良好的用户体验。为了实现这一目标,网站性能优化变得至关重要...
    99+
    2024-02-02
    减少文件大小 适当压缩图片大小 分布式部署 异步加载
  • python 性能提升之 并行map
    前段时间进行单一目录下10万张图片发送,效果很差,数据积压原来越多。 性能问题提上议程。 采用多线程 多进程 感觉比较繁琐,网上有介绍 map的并行处理的,使用后性能提高明细。 网上介绍map如下 介绍:Map Map是一个很棒的小功能...
    99+
    2023-01-31
    性能 python map
  • 提升网站性能的有效方法与策略
    优化网站性能的实用方法与策略 随着互联网的快速发展和普及,网站已经成为人们获取信息、进行交流和进行商业活动的重要平台。然而,用户对网站的使用体验要求越来越高,对网站的加载速度和响应速度也提出了更高的要求。因此,优化网站性能成为了...
    99+
    2024-02-03
    图片优化 压缩技术 缓存策略 异步加载 延迟加载
  • 如何关闭PHP的提醒功能?几种方法介绍
    PHP是一种广泛使用的开发语言,不仅在网站开发中得到了广泛的应用,还在桌面应用程序和移动设备应用程序中使用。然而,在PHP编程中可能会遇到一些问题,其中一个常见的问题是关闭PHP的提醒功能。这种提醒功能被认为具有干扰开发过程的负面影响,下面...
    99+
    2023-05-14
    php
  • Python 连接 MySQL 的几种方法
    尽管很多 NoSQL 数据库近几年大放异彩,但是像 MySQL 这样的关系型数据库依然是互联网的主流数据库之一,每个学 Python 的都有必要学好一门数据库,不管你是做数据分析,还是网络爬虫,Web 开发、亦或是机...
    99+
    2022-05-26
    python MySQL python 连接MySQL
  • Python编程通过懒属性提升性能
    目录为什么需要懒加载如何使用懒加载最后的话懒加载是一种编程范式,它推迟加载操作,直到不得不这样做。通常,当操作开销很大,需要耗费大量时间或空间时,惰性求值是首选实现。例如,在 Pyt...
    99+
    2024-04-02
  • PHP Linux脚本调优技巧:提升性能的方法
    引言:在开发和运维中,我们经常会遇到需要优化提升性能的情况。对于使用PHP开发的Linux脚本来说,优化是极其关键的。本文将介绍一些PHP Linux脚本调优的技巧和方法,并给出具体的代码示例,帮助读者更好地理解和应用。一、使用适当的数据结...
    99+
    2023-10-21
    Linux PHP 关键词: 脚本调优
  • 最大限度提升虚拟内存性能的方法
    如今已经进入大内存时代,如何设置虚拟内存才能获得最大限度的性能提升呢本期董师傅将针对这个问题展开讨论。禁用虚拟内存可提升系统性能在内存较小的年代,设置虚拟内存的必要性大家都比较清楚。现在内存的价格越来越便宜,很多朋友都...
    99+
    2023-05-25
    虚拟内存 限度 性能 方法
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作