-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathstep1_toxlsx.py
88 lines (70 loc) · 3.67 KB
/
step1_toxlsx.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 os
import pandas as pd
from pathlib import Path
Path('data').mkdir(parents=True, exist_ok=True)
inference_path = './data/inference/'
def check_questionfile(file):
return (len(file)-len('questions')-4)==file.rfind('questions')
def read_lines(filename):
lines = open(filename, 'r').readlines()
return [line.replace('\n', '') for line in lines if line.replace('\n', '')!='']
def main():
q_counter = 0
book_id = 0
for split in ['train', 'val', 'test']:
mapping = None
DATA_PATH = './data/split/{}'.format(split)
for subdir, dirs, files in os.walk(DATA_PATH):
for file in files:
if check_questionfile(file):
q_df = pd.read_csv(os.path.join(subdir, file))
s_df = pd.read_csv(os.path.join(subdir, file.replace('questions', 'story')))
col_names=q_df.columns.tolist()
col_names.insert(2,'inference')
q_df=q_df.reindex(columns=col_names)
col_names=q_df.columns.tolist()
col_names.insert(2,'book_id')
q_df=q_df.reindex(columns=col_names)
col_names=q_df.columns.tolist()
col_names.insert(2,'book_name')
q_df=q_df.reindex(columns=col_names)
col_names=q_df.columns.tolist()
col_names.insert(2,'section_id')
q_df=q_df.reindex(columns=col_names)
counter = {}
for i in range(q_df.shape[0]):
if q_df.loc[i, 'local-or-sum']=='summary' or ',' in str(q_df.loc[i, 'cor_section']):
continue
idx = q_df.loc[i, 'cor_section']
inference_name = inference_path + split + '_' + file.replace('.csv', '_') + str(int(float(idx))) + '.txt'
inference_lines = read_lines(inference_name)
if idx in counter:
counter[idx] += 1
else:
counter[idx] = 0
# print(counter[idx])
# print(len(inference_lines))
print(subdir, file, idx)
inference = inference_lines[counter[idx]]
q_df.loc[i, 'inference'] = inference
is_modify = False
for k, j in enumerate(s_df['section'].to_list()):
if int(float(j))==int(float(idx)):
q_df.loc[i, 'cor_section'] = s_df.loc[k, 'text'].replace('\n',' ').replace('\r',' ')
q_df.loc[i, 'book_id'] = book_id
q_df.loc[i, 'book_name'] = file.replace('questions', 'story')
q_df.loc[i, 'section_id'] = idx
is_modify = True
break
if is_modify == False:
raise ValueError('error')
if mapping is None:
mapping = q_df
else:
mapping = pd.concat([mapping, q_df])
q_counter+=q_df.shape[0]
book_id+=1
print(mapping.shape[0])
mapping.to_excel('data/{}.xlsx'.format(split))
print(q_counter)
main()