-
Notifications
You must be signed in to change notification settings - Fork 1
/
xml_to_csv.py
85 lines (70 loc) · 2.89 KB
/
xml_to_csv.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
import json
import os
import glob
import pandas as pd
import argparse
import xml.etree.ElementTree as ET
def __list_to_csv(annotations, output_file):
column_name = [
'filename', 'width', 'height', 'class', 'xmin', 'ymin', 'xmax', 'ymax'
]
xml_df = pd.DataFrame(annotations, columns=column_name)
xml_df.to_csv(output_file, index=None)
def xml_to_csv(xml_dir, output_file):
"""Reads all XML files, generated by labelImg, from a directory and generates a single CSV file"""
annotations = []
for xml_file in glob.glob(xml_dir + '/*.xml'):
tree = ET.parse(xml_file)
root = tree.getroot()
for member in root.findall('object'):
value = (root.find('filename').text,
int(root.find('size')[0].text),
int(root.find('size')[1].text), member[0].text,
int(member[4][0].text), int(member[4][1].text),
int(member[4][2].text), int(member[4][3].text))
annotations.append(value)
__list_to_csv(annotations, output_file)
def json_to_csv(input_json, output_file):
"""Reads a JSON file, generated by the VGG Image Annotator, and generates a single CSV file"""
with open(input_json) as f:
images = json.load(f)
annotations = []
for entry in images:
filename = images[entry]['filename']
for region in images[entry]['regions']:
c = region['region_attributes']['class']
xmin = region['shape_attributes']['x']
ymin = region['shape_attributes']['y']
xmax = xmin + region['shape_attributes']['width']
ymax = ymin + region['shape_attributes']['height']
width = 0
height = 0
value = (filename, width, height, c, xmin, ymin, xmax, ymax)
annotations.append(value)
__list_to_csv(annotations, output_file)
if __name__ == "__main__":
parser = argparse.ArgumentParser(
description=
'Reads all XML files, generated by labelImg, from a directory and generates a single CSV file',
formatter_class=argparse.RawDescriptionHelpFormatter)
parser.add_argument('type',
metavar='type',
default='xml',
choices=['xml', 'json'],
help='LabelImg XML or VIA JSON')
parser.add_argument(
'input',
metavar='input',
type=str,
help=
'Directory containing the XML files generated by labelImg or path to a single VIA JSON'
)
parser.add_argument('output_csv',
metavar='output_csv',
type=str,
help='Path where the CSV output will be created')
args = parser.parse_args()
if args.type == 'xml':
xml_to_csv(args.input, args.output_csv)
elif args.type == 'json':
json_to_csv(args.input, args.output_csv)