-
Notifications
You must be signed in to change notification settings - Fork 88
/
Copy pathparse_data.py
61 lines (52 loc) · 2.23 KB
/
parse_data.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
# from __future__ import absolute_import
from __future__ import print_function
from __future__ import division
import json
import argparse
import random
if __name__ == '__main__':
random.seed(42)
parser = argparse.ArgumentParser()
parser.add_argument('data', type=str, help='Path to the dataset file')
parser.add_argument('--outfile', default='data/train_parsed.json',
type=str, help='Desired path to output train json')
parser.add_argument('--outfile_valid', default='data/valid_parsed.json',
type=str, help='Desired path to output valid json')
parser.add_argument('--train_ratio', default=1., type=float,
help='ratio for train/val split')
args = parser.parse_args()
with open(args.data, 'r') as f:
data = json.load(f)
data = data['data']
# Lists containing ContextQuestionAnswerS
train_cqas = []
valid_cqas = []
for topic in data:
cqas = [{'context': paragraph['context'],
'id': qa['id'],
'question': qa['question'],
'answer': qa['answers'][0]['text'],
'answer_start': qa['answers'][0]['answer_start'],
'answer_end': qa['answers'][0]['answer_start'] + \
len(qa['answers'][0]['text']) - 1,
'topic': topic['title'] }
for paragraph in topic['paragraphs']
for qa in paragraph['qas']]
if random.random() < args.train_ratio:
train_cqas += cqas
else:
valid_cqas += cqas
if args.train_ratio == 1.:
print('Writing to file {}...'.format(args.outfile), end='')
with open(args.outfile, 'w') as fd:
json.dump(train_cqas, fd)
print('Done!')
else:
print('Train/Val ratio is {}'.format(len(train_cqas) / len(valid_cqas)))
print('Writing to files {}, {}...'.format(args.outfile,
args.outfile_valid), end='')
with open(args.outfile, 'w') as fd:
json.dump(train_cqas, fd)
with open(args.outfile_valid, 'w') as fd:
json.dump(valid_cqas, fd)
print('Done!')