Python 3のtimeitモジュールの使い方

PYTHON3 チュートリアル

Python 3のtimeitモジュールを使ってコードの実行時間を測定する方法

Pythonでコードのパフォーマンスを最適化する際に、特定のコードブロックの実行時間を測定することは非常に重要です。Pythonには、そのための便利なモジュールとしてtimeitがあります。この記事では、Python 3のtimeitモジュールを使って、どのようにコードの実行時間を測定するかを詳しく説明します。具体的なサンプルコードとその出力も紹介します。

timeitモジュールの基本的な使い方

timeitモジュールは、特定のコードスニペットの実行時間を測定するためのツールです。特に、コードのパフォーマンスを比較するために便利です。以下は、基本的なtimeitの使用方法です。

import timeit

# 測定したいコードを関数として定義
def example_function():
    return sum(range(100))

# timeitを使用して実行時間を測定
execution_time = timeit.timeit(example_function, number=1000)
print(f"Execution time: {execution_time} seconds")

この例では、example_functionが1000回実行され、その平均実行時間が計測されます。numberパラメータを調整することで、実行回数を変更できます。

コマンドラインからのtimeitの使用

timeitモジュールは、Pythonスクリプト内で使用するだけでなく、コマンドラインから直接使用することもできます。以下はその例です。

python -m timeit -s "from __main__ import example_function" "example_function()"

このコマンドは、example_functionをインポートし、デフォルトの実行回数である100万回実行して、その平均実行時間を測定します。

異なるコードのパフォーマンスを比較する

timeitを使用すると、異なるコードスニペットのパフォーマンスを比較することも容易です。以下に、リスト内包表記とループを使用したリストの生成を比較する例を示します。

list_comprehension_time = timeit.timeit("[x for x in range(1000)]", number=1000)
loop_time = timeit.timeit("""
result = []
for x in range(1000):
    result.append(x)
""", number=1000)

print(f"List comprehension time: {list_comprehension_time} seconds")
print(f"Loop time: {loop_time} seconds")

この例では、リスト内包表記とループのそれぞれの実行時間が測定され、結果としてどちらが速いかを確認できます。

timeitの応用:引数付き関数の測定

timeitを使用して、引数を持つ関数の実行時間を測定することも可能です。以下にその方法を示します。

def add(a, b):
    return a + b

# 引数を渡すためにlambdaを使用
execution_time_with_args = timeit.timeit(lambda: add(1, 2), number=1000)
print(f"Execution time with arguments: {execution_time_with_args} seconds")

この方法では、lambdaを使用して引数を持つ関数をtimeitに渡すことができます。

まとめ

timeitモジュールは、Pythonでのコードのパフォーマンス測定において非常に強力なツールです。この記事では、基本的な使用方法から応用例までを紹介しました。timeitを活用することで、コードの最適化をより効果的に行うことができるでしょう。

今後も、timeitを活用してPythonコードのパフォーマンス向上を図ってください。

Python 3のtimeitモジュールは、コードの実行時間を計測するためのツールです。timeitモジュールを使用すると、特定のコードブロックの実行時間を簡単に計測することができます。

timeitモジュールを使用するには、まずtimeitモジュールをインポートします。次に、timeitモジュールのTimerクラスを使用して計測したいコードを指定します。Timerオブジェクトを作成した後、timeit()メソッドを使用して実行時間を計測します。

以下は、timeitモジュールを使用してコードの実行時間を計測する例です。

“`python
import timeit

code_to_measure = ”’
# ここに計測したいコードを記述
”’

timer = timeit.Timer(stmt=code_to_measure)
execution_time = timer.timeit(number=1000) # 1000回実行した場合の平均実行時間を計測

print(f”Execution time: {execution_time} seconds”)
“`

このようにして、Python 3のtimeitモジュールを使用してコードの実行時間を計測することができます。

購読
通知
0 Comments
Inline Feedbacks
View all comments