我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python怎么进行基准测试

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

python怎么进行基准测试

这篇文章将为大家详细讲解有关python怎么进行基准测试,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

python是什么意思

Python是一种跨平台的、具有解释性、编译性、互动性和面向对象的脚本语言,其最初的设计是用于编写自动化脚本,随着版本的不断更新和新功能的添加,常用于用于开发独立的项目和大型项目。

基准测试属于性能测试的一种,用于评估和衡量软件的性能指标。我们可以在软件开发的某个阶段通过基准测试建立一个已知的性能水平,称为"基准线"。当系统的软硬件环境发生变化之后再进行一次基准测试以确定那些变化对性能的影响。 这是基准测试最常见的用途。

Donald Knuth在1974年出版的《Structured Programming with go to Statements》提到:

毫无疑问,对效率的片面追求会导致各种滥用。程序员会浪费大量的时间在非关键程序的速度上,实际上这些尝试提升效率的行为反倒可能产生很大的负面影响,特别是当调试和维护的时候。我们不应该过度纠结于细节的优化,应该说约97%的场景:过早的优化是万恶之源。
当然我们也不应该放弃对那关键3%的优化。一个好的程序员不会因为这个比例小就裹足不前,他们会明智地观察和识别哪些是关键的代码;但是仅当关键代码已经被确认的前提下才会进行优化。对于很多程序员来说,判断哪部分是关键的性能瓶颈,是很容易犯经验上的错误的,因此一般应该借助测量工具来证明。

虽然经常被解读为不需要关心性能,但是的少部分情况下(3%)应该观察和识别关键代码并进行优化。

基准(benchmarking)测试工具

python中提供了非常多的工具来进行基准测试。

为了使演示的例子稍微有趣,我们来随机生成一个列表,并对列表中数字进行排序。

import randomdef random_list(start, end, length):    """    生成随机列表    :param start: 随机开始数    :param end: 随机结束数    :param length: 列表长度    """    data_list = []    for i in range(length):        data_list.append(random.randint(start, end))    return data_listdef bubble_sort(arr):    """    冒泡排序: 对列表进行排序    :param arr 列表    """    n = len(arr)    for i in range(n):        for j in range(0, n - i - 1):            if arr[j] > arr[j + 1]:                arr[j], arr[j + 1] = arr[j + 1], arr[j]    return arrif __name__ == '__main__':    get_data_list = random_list(1, 99, 10)    ret = bubble_sort(get_data_list)    print(ret)

运行结果如下:

❯ python .\demo.py[8, 16, 22, 31, 42, 58, 66, 71, 73, 91]

timeit

timeit是python自带的模块,用来进行基准测试非常方便。

if __name__ == '__main__':    import timeit    get_data_list = random_list(1, 99, 10)    setup = "from __main__ import bubble_sort"    t = timeit.timeit(        stmt="bubble_sort({})".format(get_data_list),        setup=setup        )    print(t)

运行结果:

❯ python .\demo.py5.4201355

以测试bubble_sort()函数为例。timeit.timeit() 参数说明。

  • stmt:需要测试的函数或语句,字符串形式.

  • setup: 运行的环境,本例子中表示if __name__ == '__main__':.

  • number: 执行的次数,省缺则默认是1000000次。所以你会看到运行bubble_sort() 耗时 5秒多。

pyperf

https://github.com/psf/pyperf

pyperf 的用法与timeit比较类似,但它提供了更丰富结果。(注:我完全是发现了这个库才学习基准测试的)

if __name__ == '__main__':    get_data_list = random_list(1, 99, 10)    import pyperf    setup = "from __main__ import bubble_sort"    runner = pyperf.Runner()    runner.timeit(name="bubble sort",                  stmt="bubble_sort({})".format(get_data_list),                  setup=setup)

运行结果:

❯ python  .\demo.py -o bench.json.....................bubble sort: Mean +- std dev: 5.63 us +- 0.31 us

测试结果会写入bench.json 文件。可以使用pyperf stats命令分析测试结果。

❯ python -m pyperf stats bench.jsonTotal duration: 15.9 secStart date: 2021-04-02 00:17:18End date: 2021-04-02 00:17:36Raw value minimum: 162 msRaw value maximum: 210 msNumber of calibration run: 1Number of run with values: 20Total number of run: 21Number of warmup per run: 1Number of value per run: 3Loop iterations per value: 2^15Total number of values: 60Minimum:         4.94 usMedian +- MAD:   5.63 us +- 0.12 usMean +- std dev: 5.63 us +- 0.31 usMaximum:         6.41 us  0th percentile: 4.94 us (-12% of the mean) -- minimum  5th percentile: 5.10 us (-9% of the mean) 25th percentile: 5.52 us (-2% of the mean) -- Q1 50th percentile: 5.63 us (+0% of the mean) -- median 75th percentile: 5.81 us (+3% of the mean) -- Q3 95th percentile: 5.95 us (+6% of the mean)100th percentile: 6.41 us (+14% of the mean) -- maximumNumber of outlier (out of 5.07 us..6.25 us): 6

pytest-benchmark

https://github.com/ionelmc/pytest-benchmark

pytest-benchmark是 pytest单元测试框架的一个插件。 单独编写单元测试用例:

from demo import bubble_sortdef test_bubble_sort(benchmark):    test_list = [5, 2, 4, 1, 3]    result = benchmark(bubble_sort, test_list)    assert result == [1, 2, 3, 4, 5]

需要注意:

  • 导入bubble_sort() 函数。

  • benchmark 作为钩子函数使用,不需要导入包。前提是你需要安装pytest和pytest-benchmark。

  • 为了方便断言,我们就把要排序的数固定下来了。

运行测试用例:

❯ pytest -q .\test_demo.py.                                                                       [100%]------------------------------------------------ benchmark: 1 tests -----------------------------------------------Name (time in us)        Min       Max    Mean  StdDev  Median     IQR   Outliers  OPS (Kops/s)  Rounds  Iterations-------------------------------------------------------------------------------------------------------------------test_bubble_sort      1.6000  483.2000  1.7647  2.6667  1.7000  0.0000  174;36496      566.6715  181819           1-------------------------------------------------------------------------------------------------------------------Legend:  Outliers: 1 Standard Deviation from Mean; 1.5 IQR (InterQuartile Range) from 1st Quartile and 3rd Quartile.  OPS: Operations Per Second, computed as 1 / Mean1 passed in 1.98s

加上 --benchmark-histogram 参数,你会得到一张图表

❯ pytest -q .\test_demo.py --benchmark-histogram.                                                                                                                [100%]------------------------------------------------ benchmark: 1 tests -----------------------------------------------Name (time in us)        Min      Max    Mean  StdDev  Median     IQR    Outliers  OPS (Kops/s)  Rounds  Iterations-------------------------------------------------------------------------------------------------------------------test_bubble_sort      1.6000  53.9000  1.7333  0.3685  1.7000  0.0000  1640;37296      576.9264  178572           1-------------------------------------------------------------------------------------------------------------------Generated histogram: D:\github\test-circle\article\code\benchmark_20210401_165958.svg

图片如下:

python怎么进行基准测试

关于“python怎么进行基准测试”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

python怎么进行基准测试

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

python怎么进行基准测试

这篇文章将为大家详细讲解有关python怎么进行基准测试,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。python是什么意思Python是一种跨平台的、具有解释性、编译性、互动性和面向对象的脚本语言,其最
2023-06-14

python如何进行基准测试

基准测试属于性能测试的一种,用于评估和衡量软件的性能指标。我们可以在软件开发的某个阶段通过基准测试建立一个已知的性能水平,称为"基准线"。当系统的软硬件环境发生变化之后再进行一次基准测试以确定那些变化对性能的影响。 这是基准测试最常见的用途
2022-06-02

怎么使用HammerDB进行MySQL基准测试

使用HammerDB进行MySQL基准测试的步骤如下:首先,下载并安装HammerDB。你可以在HammerDB的官方网站(https://www.hammerdb.com/)上找到最新的版本,并根据操作系统的要求进行安装。启动Hammer
2023-10-24

怎么使用HammerDB进行MySQL基准测试

HammerDBHammerDB是一种开源MySQL基准测试工具,用于评估数据库性能。它提供多种测试场景和指标,让数据库管理员了解系统瓶颈。HammerDB可识别连接限制、CPU使用率高和延迟,并提供优化配置的建议。通过比较结果,可以监控性能改进。遵循最佳实践(如在测试环境中运行和使用真实数据)以确保准确的基准测试。
怎么使用HammerDB进行MySQL基准测试
2024-04-12

如何使用HammerDB进行MySQL基准测试

使用HammerDB进行MySQL基准测试HammerDB是一款开源工具,可用于对MySQL数据库执行负载测试和基准测试。它模拟真实世界负载,提供有关MySQL性能和可扩展性的见解。配置和运行:安装HammerDB并对其进行配置以连接到MySQL数据库。通过运行一个命令启动基准测试,实时监视指标并记录结果。分析和改进:分析HammerDB报告以识别性能瓶颈和进行改进。高级功能允许进行可自定义负载测试、并行测试和定制指标监视。最佳实践:使用类似于生产环境的硬件,逐步增加负载,并重复基准测试以获得准确的结果。
如何使用HammerDB进行MySQL基准测试
2024-04-13

怎么用PL/SQL进行数据库性能基准测试

要使用PL/SQL进行数据库性能基准测试,可以按照以下步骤进行:创建测试表:首先,创建一个测试表来存储测试数据。可以使用以下SQL语句创建一个简单的测试表:CREATE TABLE test_table (id NUMBER,name VA
怎么用PL/SQL进行数据库性能基准测试
2024-05-08

Sysbench对Mysql进行基准测试过程解析

前言 1.基准测试(benchmarking)是性能测试的一种类型,强调的是对一类测试对象的某些性能指标进行定量的、可复现、可对比的测试。进一步来理解,基准测试是在某个时候通过基准测试建立一个已知的性能水平(称为基准线),当系统的软硬件环境
2022-05-10

基于java的api怎么进行测试

要使用Java的API进行测试,可以使用各种测试框架和工具,如JUnit、TestNG、Mockito等。以下是一些基本步骤来进行API测试:1. 导入所需的测试框架和工具的库或依赖项。2. 创建一个测试类,并使用@Test注解标记要测试的
2023-09-08

Java使用JMH进行基准性能测试分析

本篇内容主要讲解“Java使用JMH进行基准性能测试分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java使用JMH进行基准性能测试分析”吧!一、前言在日常开发工作当中,开发人员可能有这些困
2023-06-25

如何对 C++ 函数性能进行基准测试?

为 c++++ 函数进行基准测试,可采取以下步骤:使用计时工具(如 std::chrono 库)测量执行时间。编写基准测试函数以执行代码并返回执行时间。利用基准测试库获取高级功能,如统计收集和比较。如何对 C++ 函数性能进行基准测试基准
如何对 C++ 函数性能进行基准测试?
2024-04-19

Hardhat怎么进行合约测试环境准备

这篇文章主要介绍了Hardhat怎么进行合约测试环境准备的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Hardhat怎么进行合约测试环境准备文章都会有所收获,下面我们一起来看看吧。引言Hardhat是一个开源的
2023-07-05

如何使用BenchmarkDotNet对C#代码进行基准测试

这篇文章给大家分享的是有关如何使用BenchmarkDotNet对C#代码进行基准测试的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。BenchmarkDotNet 是一个轻量级,开源的,强大的 .NET 工具包,
2023-06-14

怎么进行Web渗透测试

今天小编给大家分享一下怎么进行Web渗透测试的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。渗透测试,是渗透测试工程师完全模拟
2023-06-05

Perl中怎么进行测试和调试

在Perl中进行测试和调试通常使用的工具包括Test模块和调试器。以下是一些常用的方法:使用Test模块进行单元测试:Test模块是Perl中用于编写和运行测试的标准模块。您可以使用Test::Simple、Test::More等模块来编写
Perl中怎么进行测试和调试
2024-03-05

Linux怎么进行压力测试

这篇文章主要介绍“Linux怎么进行压力测试”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Linux怎么进行压力测试”文章能帮助大家解决问题。软件压力测试是一种基本的质量保证行为,它是每个重要软件测
2023-06-27

并行运行基准测试,即模拟同时请求

从现在开始,努力学习吧!本文《并行运行基准测试,即模拟同时请求》主要讲解了等等相关知识点,我会在编程网中持续更新相关的系列文章,欢迎大家关注并积极留言建议。下面就先一起来看一下本篇正文内容吧,希望能帮到你!问题内容当测试从 api 调用的数
并行运行基准测试,即模拟同时请求
2024-04-04

【星云测试】开发者测试-采用精准测试工具对Spring Boot应用进行测试

简介:本文主要介绍把现今主流的springboot框架项目和精准测试工具进行结合和应用,通过精准测试的数据穿透、数据采集、测试用例与代码的双向追溯、数据分析等一系列精准测试的特有功能,达到对项目质量的保证。 本次环境搭建分为基础环境准备、s
2023-06-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录