Python轻松获取CPU使用率方法
你在学习文章相关的知识吗?本文《Python统计CPU使用率的简单方法》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!
最直接跨平台计算Python脚本CPU使用率的方法是使用psutil库,通过process.cpu_percent(interval=1)监控进程级CPU占用,结合循环采样获取平均值与峰值,用于识别性能瓶颈。
在Python脚本执行过程中计算CPU使用率,最直接有效且跨平台的方式是利用psutil
库。它能让你轻松地获取当前进程乃至整个系统的CPU占用情况,对于性能分析来说,这几乎是首选工具。
解决方案
要计算Python脚本的CPU使用率,我们通常会用到psutil
库。这个库提供了访问系统进程和系统利用率(CPU、内存、磁盘、网络等)的功能。
首先,你得安装它:
pip install psutil
接着,在你的Python脚本里,你可以这样来测量当前进程的CPU使用率:
import psutil import time import os def cpu_intensive_task(): """一个模拟CPU密集型任务的函数""" result = 0 for i in range(1, 5000000): # 增加循环次数以确保CPU占用 result += i * i return result def monitor_cpu_usage(): """监控当前脚本CPU使用率的示例""" process = psutil.Process(os.getpid()) # 获取当前进程对象 print(f"开始监控PID: {process.pid} 的CPU使用率...") # 第一次调用cpu_percent()会返回0.0,因为它需要一个基准时间点来计算 # 所以通常需要调用两次,或者在循环中持续调用 process.cpu_percent(interval=None) # 第一次调用,用于初始化 start_time = time.time() duration = 10 # 监控时长 cpu_usages = [] while time.time() - start_time < duration: # interval=1 表示在过去1秒内的CPU使用率 # 如果不设置interval,它会计算从上次调用到现在的CPU使用率 cpu_percent = process.cpu_percent(interval=1) cpu_usages.append(cpu_percent) print(f"当前CPU使用率: {cpu_percent}%") # time.sleep(1) # psutil.cpu_percent内部会处理间隔,这里可以省略,除非你想更慢的采样 print("\n任务完成,正在分析CPU使用率数据...") if cpu_usages: avg_cpu = sum(cpu_usages) / len(cpu_usages) max_cpu = max(cpu_usages) print(f"平均CPU使用率: {avg_cpu:.2f}%") print(f"峰值CPU使用率: {max_cpu:.2f}%") else: print("未收集到CPU使用率数据。") print("\n现在运行一个CPU密集型任务来观察效果...") # 在运行CPU密集型任务时同时监控 process.cpu_percent(interval=None) # 重置,准备新的测量 task_start_time = time.time() # 启动一个线程或进程来运行CPU密集型任务,同时主线程监控 # 这里为了简化,直接在主线程中运行并监控 cpu_intensive_start_time = time.time() cpu_intensive_task() # 运行CPU密集型任务 cpu_intensive_end_time = time.time() print(f"CPU密集型任务耗时: {cpu_intensive_end_time - cpu_intensive_start_time:.2f} 秒") # 任务结束后,再获取一次CPU使用率,这会是任务期间的平均值 # 注意:这种单次测量无法反映任务期间的实时波动 final_cpu_percent = process.cpu_percent(interval=1) print(f"任务结束后测量的CPU使用率 (过去1秒): {final_cpu_percent}%") if __name__ == "__main__": monitor_cpu_usage() # 也可以直接获取系统整体的CPU使用率 # print(f"\n系统整体CPU使用率 (过去1秒): {psutil.cpu_percent(interval=1)}%") # print(f"系统整体每个核心CPU使用率: {psutil.cpu_percent(interval=1, percpu=True)}")
这段代码里,process.cpu_percent(interval=1)
会返回自上次调用此方法以来,当前进程在过去1秒内的CPU使用率。如果interval
设为None
,它会计算自上次调用以来的CPU使用率。这对于快速采样非常有用。我个人觉得,对于大多数性能分析场景,设置一个合理的interval
(比如1秒)来周期性采样,会得到更稳定的数据。
为什么需要监控Python脚本的CPU使用率?
监控CPU使用率,说白了,就是为了搞清楚你的Python脚本到底“忙”不忙,忙在什么地方。这对于性能优化简直是基石。想象一下,你的程序跑得很慢,但你不知道是CPU在苦苦计算,还是在等待硬盘I/O,又或者是在等待网络响应。如果CPU使用率很高,那说明你的代码逻辑本身可能就是瓶颈,比如有复杂的循环、大量的数学运算、或者低效的算法。
反过来,如果CPU使用率一直很低,但程序还是慢,那很可能就是I/O密集型任务(比如读写大文件、数据库查询、网络请求)在拖后腿。这时候你再去优化计算逻辑,那简直是南辕北辙。识别CPU瓶颈,能让你把优化精力集中在真正能带来提升的地方,而不是瞎忙活。这就像医生看病,得先诊断出病灶在哪儿,才能对症下药。
除了psutil,还有哪些方法可以监测Python脚本的CPU使用率?
当然有,psutil
是Python内部解决这个问题的优雅方式,但我们也可以借助一些系统级的工具。
首先是经典的top
和htop
。在Linux/Unix系统上,直接在终端输入top
或htop
,就能看到当前系统所有进程的资源占用情况,包括CPU、内存等等。你可以根据进程ID(PID)找到你的Python脚本,然后观察它的CPU使用率。htop
相比top
界面更友好,功能也更多,比如可以方便地排序、筛选。这对于快速查看系统概览非常方便,但缺点是它不能集成到你的Python代码里进行自动化监控。
再来就是Linux下的perf
工具。这玩意儿可就厉害了,它是Linux内核提供的性能分析工具,能深入到函数级别甚至指令级别去分析CPU的活动。比如你可以用perf top -p
来实时查看某个进程最耗CPU的函数。不过,perf
的学习曲线相对陡峭,而且它主要是针对Linux系统,跨平台性不如psutil
。
对于更宏观的,或者说只是想知道脚本跑完总共用了多少CPU时间,time
命令也能提供一些信息。在终端里,你可以在运行Python脚本前加上time
,比如time python your_script.py
。它会输出脚本的真实时间(real)、用户CPU时间(user)和系统CPU时间(sys)。用户CPU时间是你的程序代码在用户态消耗的CPU时间,系统CPU时间是你的程序调用系统内核服务消耗的CPU时间。虽然它不能给出实时百分比,但能帮你理解脚本的总CPU消耗。
我个人觉得,对于日常的Python脚本性能分析,psutil
是首选,因为它方便、灵活,而且能直接集成到你的代码里。当你需要更深入的系统级分析时,再考虑top
/htop
或perf
这些外部工具。
如何正确解读CPU使用率数据?
解读CPU使用率数据,这事儿可没那么简单,尤其是在多核处理器普及的今天。你看到一个百分比,它背后可能藏着好几种含义。
最常见的一个误解就是,如果你的单线程Python脚本在8核CPU上跑,你可能看到它的CPU使用率只有12.5%(100% / 8核),但实际上,它可能已经把其中一个核心跑满了。psutil.cpu_percent()
默认返回的是相对于整个系统CPU能力的百分比。所以,一个单线程CPU密集型任务,在多核CPU上,它的最大“理论”使用率就是100% / 核心数
。如果你想知道某个进程在它所运行的那个核心上是不是跑满了,那就需要更细致的分析,或者结合percpu=True
参数来查看每个核心的使用率,然后判断你的进程主要跑在哪个核心上。
另外,CPU使用率还分用户态(user)和内核态(system)。用户态CPU时间是你的应用程序代码直接执行所消耗的CPU时间,而内核态CPU时间则是你的应用程序请求操作系统服务(比如文件I/O、网络通信)时,内核代码执行所消耗的CPU时间。如果系统CPU使用率很高,那可能意味着你的程序频繁地进行系统调用,或者系统本身负载较重。
还有一点,CPU使用率是瞬时值或者某个时间段的平均值。一个峰值可能只是昙花一现,而一个持续的高平均值才真正值得关注。所以,在做性能分析时,不要只盯着一个数字,要看趋势,看它在不同阶段的变化。如果你的脚本在某个特定环节CPU飙升,那那个环节就是你优化的重点。
最后,别忘了I/O等待(iowait)。有时候CPU使用率看起来不高,但系统整体却很慢,这可能是因为大量的CPU时间花在了等待I/O操作完成上。虽然iowait
不直接计入用户或系统CPU时间,但它会影响CPU的有效利用率。psutil
也能提供这些信息,比如psutil.cpu_times_percent()
可以返回更详细的CPU时间分类。理解这些细微之处,才能真正从CPU使用率数据中挖掘出有价值的信息。
今天关于《Python轻松获取CPU使用率方法》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于监控,性能优化,psutil,PythonCPU使用率,process.cpu_percent的内容请关注golang学习网公众号!

- 上一篇
- LogMeInHamachi流量过滤配置方法

- 下一篇
- 7-Zip隐藏文件压缩技巧全解析
-
- 文章 · python教程 | 4分钟前 |
- 正则中的原子组是什么?怎么使用?
- 175浏览 收藏
-
- 文章 · python教程 | 8分钟前 |
- Python发邮件教程:smtplib使用全解析
- 424浏览 收藏
-
- 文章 · python教程 | 59分钟前 |
- Pythongroupby数据聚合技巧详解
- 158浏览 收藏
-
- 文章 · python教程 | 1小时前 | Python脚本 运行Python脚本
- 暂停运行中的Python脚本的技巧
- 241浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- 非捕获分组作用及使用技巧
- 455浏览 收藏
-
- 文章 · python教程 | 2小时前 | 选择 HTML/XML beautifulsoup 数据解析 xpath
- XPath与BeautifulSoup哪个更实用?
- 223浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- SQLAlchemy只查部分字段的高效方法
- 157浏览 收藏
-
- 文章 · python教程 | 3小时前 |
- Plotly交互图表教程:Python数据可视化指南
- 299浏览 收藏
-
- 文章 · python教程 | 3小时前 |
- Python视频流处理:OpenCV帧操作详解
- 364浏览 收藏
-
- 文章 · python教程 | 3小时前 |
- Python元编程:动态代码生成实战技巧
- 403浏览 收藏
-
- 文章 · python教程 | 3小时前 |
- Python闭包怎么用?函数嵌套全解析
- 101浏览 收藏
-
- 文章 · python教程 | 3小时前 |
- 正则提取HTML内容方法全解析
- 153浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 512次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 499次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 千音漫语
- 千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
- 795次使用
-
- MiniWork
- MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
- 755次使用
-
- NoCode
- NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
- 786次使用
-
- 达医智影
- 达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
- 802次使用
-
- 智慧芽Eureka
- 智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
- 780次使用
-
- Flask框架安装技巧:让你的开发更高效
- 2024-01-03 501浏览
-
- Django框架中的并发处理技巧
- 2024-01-22 501浏览
-
- 提升Python包下载速度的方法——正确配置pip的国内源
- 2024-01-17 501浏览
-
- Python与C++:哪个编程语言更适合初学者?
- 2024-03-25 501浏览
-
- 品牌建设技巧
- 2024-04-06 501浏览