Python スクリプトを作成しましたが、実行に予想以上に時間がかかっており、ランタイムを占有するスクリプト内の特定の行の明確な候補がありません。
各行を実行するのにかかる時間を確認するためにコードに入れることができるものはありますか?
どうもありがとう。
Python スクリプトを作成しましたが、実行に予想以上に時間がかかっており、ランタイムを占有するスクリプト内の特定の行の明確な候補がありません。
各行を実行するのにかかる時間を確認するためにコードに入れることができるものはありますか?
どうもありがとう。
プロファイリングで python を実行してみましたか?
python -m cProfile --sort cumulative your_single_thread_script.py &> out.log
この質問で詳細を見つけることができますHow can you profile a python script?
プロファイリング ユーティリティの詳細については、こちらを参照してください。
hotshotなどのプロファイラーを使用します。それは簡単です!
1) プロファイルを使用してコードを実行します。
import hotshot
prof = hotshot.Profile("hotshot_stats.prof")
prof.runcall(my_function)
prof.close()
2) 結果のファイルを読み取ります。
from hotshot import stats
s = stats.load("hotshot_stats.prof")
s.strip_dirs()
s.sort_stats('time', 'calls')
s.print_stats(20)
timeit
Python 2.3以降の標準モジュールは、ドキュメントを参照してください。