devtools/exlog.py
author Sylvain Thenault <sylvain.thenault@logilab.fr>
Wed, 07 Jan 2009 18:30:00 +0100
changeset 350 f34ef2c64605
parent 331 1e12e8cd6901
permissions -rw-r--r--
cleanup/fix cut variants

"""
usage: python exlog.py < rql.log

will print out the following table

  total execution time || number of occurences || rql query

sorted by descending total execution time

chances are the lines at the top are the ones that will bring
the higher benefit after optimisation. Start there.
"""
import sys, re

def run():
    requests = {}
    for line in sys.stdin:
        if not ' WHERE ' in line:
            continue
        #sys.stderr.write( line )
        rql, time = line.split('--')
        rql = re.sub("(\'\w+': \d*)", '', rql)
        req = requests.setdefault(rql, [])
        time.strip()
        chunks = time.split()
        cputime = float(chunks[-3])
        req.append( cputime )

    stat = []
    for rql, times in requests.items():
        stat.append( (sum(times), len(times), rql) )

    stat.sort()
    stat.reverse()
    for time, occ, rql in stat:
        print time, occ, rql

if __name__ == '__main__':
    run()