str.startswith が遅い件

デコレータに対応するようにして、時間計測。

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

実行するたびに若干値は違うが、傾向的にはこんな感じ。文字列の比較する長さによるのかもしれないが、== を使った方法が断然早い。== が成立するときも早い。但し、バージョンが上がったときに順序が逆転する可能性もある。パフォーマンステストは難しいので、とりあえずここまでにしておくつもり。