官术网_书友最值得收藏!

The cProfile module

As discussed previously, profiling means measuring the execution time of a program. We are going to use the cProfile Python module for profiling a program.

Now, we will write a cprof_example.py script and write the following code in it:

mul_value = 0
def mul_numbers( num1, num2 ):
mul_value = num1 * num2;
print ("Local Value: ", mul_value)
return mul_value
mul_numbers( 58, 77 )
print ("Global Value: ", mul_value)

Run the program and you will see the output as follows:

student@ubuntu:~$ python3 -m cProfile cprof_example.py
Local Value: 4466
Global Value: 0
6 function calls in 0.000 seconds
Ordered by: standard name

ncalls tottime percall cumtime percall filename:lineno(function)
1 0.000 0.000 0.000 0.000 cprof_example.py:1(<module>)
1 0.000 0.000 0.000 0.000 cprof_example.py:2(mul_numbers)
1 0.000 0.000 0.000 0.000 {built-in method builtins.exec}
2 0.000 0.000 0.000 0.000 {built-in method builtins.print}
1 0.000 0.000 0.000 0.000 {method 'disable' of '_lsprof.Profiler' objects}

So, using cProfile, all functions that are called will get printed with the time spent on each function. Now, we will see what these column headings mean:

  • ncalls: Number of calls
  • tottime: Total time spent in the given function
  • percall: Quotient of tottime divided by ncalls
  • cumtime: Cumulative time spent in this and all subfunctions
  • percall: Quotient of cumtime divided by primitive calls
  • filename:lineno(function): Provides the respective data of each function
主站蜘蛛池模板: 商南县| 宝丰县| 韩城市| 保靖县| 方城县| 浮梁县| 仙游县| 沽源县| 大港区| 湟中县| 梧州市| 南陵县| 长泰县| 武安市| 宕昌县| 西林县| 石河子市| 广元市| 车险| 鄄城县| 花莲县| 丹江口市| 游戏| 彭山县| 徐水县| 夏津县| 高雄县| 荔波县| 邢台市| 广灵县| 正蓝旗| 安远县| 桐柏县| 宜黄县| 定陶县| 和平县| 冷水江市| 开平市| 蒙山县| 衡南县| 中牟县|