-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathmain.py
92 lines (67 loc) · 3.23 KB
/
main.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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
import logging
from multiprocessing import Process, Manager
from optparse import OptionParser
import progressbar
from models import PivotCacheRecords, PivotCacheDefinition
from utils import spreadsheetml_parser
def _parse_console_input():
parser = OptionParser()
parser.add_option("-f", "--file", dest="filename",
help="Path to input file", metavar="FILE")
parser.add_option("-o", "--output", dest="outputname",
help="Number of pieces to split before converting the file", metavar="FILE")
parser.add_option("-n", "--nchunks", dest="nchunks", default=5, type="int",
help="Path to output file", metavar="FILE")
parser.add_option("-v", "--verbose", dest="verbose", action="store_true",
help="Log in console", metavar="FILE")
(options, _) = parser.parse_args()
if options.filename is None:
parser.error("Filename not given")
if options.verbose is True:
logging.basicConfig(level=logging.DEBUG)
if options.outputname is None:
file_name = options.filename.split('.')
options.outputname = file_name[0] + ".csv"
return options.filename, options.outputname, options.nchunks
def _get_header(metadata):
return ",".join([column_data["column_name"] for column_data in metadata])
def _write_csv(io, string):
file = None
try:
file = open(io, "w")
file.write("".join(string))
file.flush()
except IOError:
logging.error("Output file couldn't be opened")
finally:
file.close()
if __name__ == "__main__":
file_name, output_file, n_chunks = _parse_console_input()
logging.info("Extracting pivotCacheRecords from %s..", file_name)
records = PivotCacheRecords(file_name).read()
metadatas = PivotCacheDefinition(file_name).parse()
bar = progressbar.ProgressBar(max_value=len(records) * n_chunks + 5)
for idy, xml, metadata in zip(range(1, len(records) + 1), records, metadatas):
bar.update(0)
batch_string = Manager().list()
logging.info("Extracting metadata from pivotCacheDefinition")
metadata = list(metadata)
logging.debug(metadata)
header = _get_header(metadata)
batch_string.append(header + '\n')
logging.debug(header)
logging.info("Splitting pivotCacheRecords%d.xml into %d chunks", idy, n_chunks)
chunks = spreadsheetml_parser.split_xml(xml, n_chunks)
for idx in range(len(chunks)):
logging.info("Converting chunk %d of pivotCacheRecords%d.csv", idx, idy)
valid_xml = spreadsheetml_parser.get_valid_pivot_cache_records_xml(chunks, idx)
logging.debug("Chunk head %s", valid_xml[:200])
logging.debug("Chunk tail %s", valid_xml[-200:])
p = Process(target=spreadsheetml_parser.str_xml_to_csv, args=(valid_xml, batch_string, metadata,))
p.start()
p.join()
logging.info("Chunk %d of pivotCacheRecords%d.csv successfully converted", idx, idy)
bar.update(int((idx + 1) * idy))
logging.info("Saving result in %s...", output_file)
_write_csv(output_file + '-' + str(idy), batch_string)
logging.info("CSV File %s successfully created", output_file)