view python/logoutput.py @ 797:3575840553c8

thought about putting this in example; but lets delete this instead
author Jeff Hammel <k0scist@gmail.com>
date Fri, 28 Oct 2016 10:44:50 -0700
parents d7afa7a0ea3e
children
line wrap: on
line source

#!/usr/bin/env python

"""
execute a command and log its output to a file
"""

import sys
from subprocess import list2cmdline, STDOUT
from subprocess import check_output as call

def main(args=sys.argv[1:]):
    """CLI"""

    usage = '%prog outputfile command [args]'
    usage += '\n' + __doc__
    if args < 2:
        print 'Usage: ' + usage
        sys.exit(1)

    path = args.pop(0)
    commandline = list2cmdline(args)

    with file(path, 'w') as w:
        output = call(args, stderr=STDOUT)
        w.write('\n\n'.join([commandline, output]))

if __name__ == '__main__':
    main()