Total Complexity | 4 |
Total Lines | 36 |
Duplicated Lines | 0 % |
Coverage | 93.33% |
Changes | 2 | ||
Bugs | 0 | Features | 0 |
1 | """ |
||
11 | 1 | class ShredderCommand(Command): |
|
12 | """ |
||
13 | Converteert XML-bestanden met groupertabellen naar CSV-bestanden |
||
14 | |||
15 | kerapu:shredder |
||
16 | {XML-bestand : XML-bestand met groupertabellen, b.v. BoomBestanden.xml, Referenties.xml} |
||
17 | {folder : Folder waar de CSV-bestanden moeten worden opgeslagen} |
||
18 | """ |
||
19 | |||
20 | # ------------------------------------------------------------------------------------------------------------------ |
||
21 | 1 | def handle(self): |
|
22 | """ |
||
23 | Executes the command. |
||
24 | """ |
||
25 | 1 | self.output = KerapuStyle(self.input, self.output) |
|
26 | |||
27 | 1 | filename = self.argument('XML-bestand') |
|
28 | 1 | folder = self.argument('folder') |
|
29 | |||
30 | # Lees de eerste gedeelte van het XML-bestand en bepaal type. |
||
31 | 1 | with open(filename, 'rt') as handle: |
|
32 | 1 | kop = handle.read(1024) |
|
33 | |||
34 | 1 | if '<InlezenBoomBestanden>' in kop: |
|
35 | 1 | shredder = BoomBestandenShredder(self.output, folder) |
|
36 | 1 | shredder.shred_xml_file(filename) |
|
37 | |||
38 | 1 | elif '<InlezenReferenties>' in kop: |
|
39 | 1 | shredder = ReferentieShredder(self.output, folder) |
|
40 | 1 | shredder.shred_xml_file(filename) |
|
41 | |||
42 | else: |
||
43 | raise RuntimeError("Tag <InlezenBoomBestanden> of <InlezenReferenties> niet gevonden in '{}'". |
||
44 | format(filename)) |
||
45 | |||
46 | 1 | return 0 |
|
47 | |||
49 |