forked from exponential-decay/archives-nz-rosetta-csv-ingest
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathimport-generator.py
72 lines (57 loc) · 3.06 KB
/
import-generator.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#!/usr/local/bin/python
# -*- coding: utf-8 -*-
import os
import sys
import argparse
import ConfigParser
from libs.RosettaCSVGenerator import RosettaCSVGenerator
def createImportOverview(droidcsv, configfile):
createoverview = ImportOverviewGenerator(droidcsv, configfile)
createoverview.createOverviewSheet()
def importsheetDROIDmapping(droidcsv, importschema, configfile):
importgenerator = ImportSheetGenerator(droidcsv, importschema, configfile)
importgenerator.droid2archwayimport()
def exportsheetRosettamapping(droidcsv, exportsheet, rosettaschema, configfile, provenance):
csvgen = RosettaCSVGenerator(droidcsv, exportsheet, rosettaschema, configfile, provenance)
csvgen.export2rosettacsv()
def main():
# Usage: --csv [droid report]
# Handle command line arguments for the script
parser = argparse.ArgumentParser(description='Generate Archway Import Sheet and Rosetta Ingest CSV from DROID CSV Reports.')
#TODO: Consider optional and mandatory elements... behaviour might change depending on output...
#other options droid csv and rosetta schema
#NOTE: class on its own might be used to create a blank import csv with just static options
parser.add_argument('--csv', help='Single DROID CSV to read.', default=False, required=False)
parser.add_argument('--exp', help='Archway list control sheet to map to Rosetta ingest CSV', default=False, required=False)
parser.add_argument('--ros', help='Rosetta CSV validation schema', default=False, required=False)
parser.add_argument('--cfg', help='Config file for field mapping.', default=False, required=False)
parser.add_argument('--pro','--prov', help='Flag to enable use of prov.notes file.', default=False, required=False, action="store_true")
parser.add_argument('--args','--arg', help='Concatenate arguments into a file for ease of use.', default=False, required=False)
if len(sys.argv)==1:
parser.print_help()
sys.exit(1)
# Parse arguments into namespace object to reference later in the script
global args
args = parser.parse_args()
#TODO: Additional help text to describe two discrete sets of options
if args.args:
config = ConfigParser.RawConfigParser()
config.read(args.args)
if config.has_option('arguments', 'title'):
sys.stderr.write("INFO: Using " + config.get('arguments', 'title') + " configuration file." + "\n")
else:
sys.stderr.write("Using an arguments configuration file." + "\n\n")
if config.has_option('arguments', 'droidexport'):
args.csv = config.get('arguments', 'droidexport')
args.ros = config.get('arguments', 'schemafile')
args.cfg = config.get('arguments', 'configfile')
args.exp = config.get('arguments', 'listcontrol')
#creating an ingest sheet for Rosetta...
if args.csv and args.exp and args.ros and args.cfg:
exportsheetRosettamapping(args.csv, args.exp, args.ros, args.cfg, args.pro)
#we're not doing anything sensible...
else:
parser.print_help()
sys.exit(1)
if __name__ == "__main__":
main()