1
0
Fork 0
mirror of https://github.com/Athemis/pyKinetics.git synced 2025-04-05 06:56:02 +00:00
pyKinetics/analyze-cli.py
2015-08-19 00:22:15 +02:00

109 lines
3.4 KiB
Python
Executable file

#!/usr/bin/python
# -*- coding: utf-8 -*-
import argparse
import logging
import csv
from pathlib import Path
import libkinetics
def parse_arguments():
parser = argparse.ArgumentParser()
parser.add_argument('-v',
'--verbose',
action='store_true',
help='increase output verbosity')
parser.add_argument('-wh',
'--with_hill',
action='store_true',
help='compute additional kinetics using Hill equation')
parser.add_argument('input',
type=str,
help='directory containing input files in csv format')
parser.add_argument('output',
type=str,
help='results will be written to this directory')
args = parser.parse_args()
return args
def initialize_logger():
"""
Initialization of logging subsystem. Two logging handlers are brought up:
'fh' which logs to a log file and 'ch' which logs to standard output.
:return logger: returns a logger instance
"""
logger = logging.getLogger('pyKinetics-cli')
logger.setLevel(logging.INFO)
ch = logging.StreamHandler()
ch.setLevel(logging.INFO)
logger.addHandler(ch)
try:
log_filename = 'pyKinetics-cli.log'
fh = logging.FileHandler(log_filename, 'w')
fh.setLevel(logging.INFO)
logger.addHandler(fh)
except IOError as error:
logger.warning('WARNING: Cannot create log file! Run pyKinetics-cli'
'from a directory to which you have write access.')
logger.warning(error.msg)
pass
return logger
def main():
# parse command line arguments
args = parse_arguments()
# initialize logger
logger = initialize_logger()
if args.with_hill:
do_hill = args.with_hill
else:
do_hill = False
try:
input_path = Path(args.input).resolve()
except FileNotFoundError:
logger.critical('CRITICAL: Path containing input data '
'not found: {}'.format(args.input))
raise
try:
output_path = Path(args.output).resolve()
except FileNotFoundError:
logger.critical('CRITICAL: Path for writing results '
'not found: {}'.format(args.output))
raise
if output_path.is_dir():
if input_path.is_dir():
logger.info('INFO: Collecting data files')
data_files = sorted(input_path.glob('**/*.csv'))
msg = 'Calculating kinetics'
if do_hill:
msg = '{} including Hill kinetics'.format(msg)
logger.info('INFO: {}'.format(msg))
exp = libkinetics.Experiment(data_files, (10, 25), do_hill)
logger.info('INFO: Plotting linear fits to data and kinetics')
exp.plot_data(str(output_path))
exp.plot_kinetics(str(output_path))
logger.info('INFO: Writing results to results.csv')
exp.write_data(str(output_path))
else:
msg = '{} is not a directory!'.format(input_path)
logger.critical('CRITICAL: '.format(msg))
raise ValueError(msg)
else:
msg = '{} is not a directory!'.format(output_path)
logger.critical('CRITICAL: '.format(msg))
raise ValueError(msg)
if __name__ == "__main__":
main()