str.startswith が遅い件
- どう書く?org 実行時間の測定 (http://ja.doukaku.org/22/)
デコレータに対応するようにして、時間計測。
import time def profile(func): def foo(*a, **k): t = time.time() r = func(*a, **k) print '%s: %g sec elapsed' % (func.__name__, time.time() - t) return r return foo if __name__ == '__main__': @profile def find(s1, s2): for i in xrange(100000): str.find(s1, s2) @profile def startswith(s1, s2): for i in xrange(100000): str.startswith(s1, s2) @profile def op_eql(s1, s2): for i in xrange(100000): s1[:5] == s2 find('func_name', 'test_') startswith('func_name', 'test_') op_eql('func_name', 'test_') # find: 0.0939999 sec elapsed # startswith: 0.0780001 sec elapsed # op_eql: 0.016 sec elapsed
実行するたびに若干値は違うが、傾向的にはこんな感じ。文字列の比較する長さによるのかもしれないが、== を使った方法が断然早い。== が成立するときも早い。但し、バージョンが上がったときに順序が逆転する可能性もある。パフォーマンステストは難しいので、とりあえずここまでにしておくつもり。