view python/logoutput.py @ 694:ebca6d85213a

File "/usr/lib/python3/dist-packages/IPython/config/__init__.py", line 16, in <module> from .application import * File "/usr/lib/python3/dist-packages/IPython/config/application.py", line 31, in <module> from IPython.config.configurable import SingletonConfigurable File "/usr/lib/python3/dist-packages/IPython/config/configurable.py", line 33, in <module> from IPython.utils.text import indent, wrap_paragraphs File "/usr/lib/python3/dist-packages/IPython/utils/text.py", line 28, in <module> from IPython.external.path import path File "/usr/lib/python3/dist-packages/IPython/external/path/__init__.py", line 2, in <module> from path import * File "/home/jhammel/python/path.py", line 25 print root(path) ^
author Jeff Hammel <k0scist@gmail.com>
date Wed, 09 Jul 2014 16:26:49 -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()