-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathlcquad_dataset.py
executable file
·70 lines (51 loc) · 1.78 KB
/
lcquad_dataset.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
import json
import requests, json, re, operator
import sys
from parser.lc_quad import LC_Qaud
def prepare_dataset(ds):
ds.load()
ds.parse()
return ds
def ask_query(uri):
if uri == "<https://www.w3.org/1999/02/22-rdf-syntax-ns#type>":
return 200, json.loads("{\"boolean\": \"True\"}")
uri = uri.replace("https://", "http://")
return query(u'ASK WHERE {{ {} ?u ?x }}'.format(uri))
def query(q):
q = q.replace("https://", "http://")
payload = (
('query', q),
('format', 'application/json'))
r = requests.get('http://dbpedia.org/sparql', params=payload)
return r.status_code, r.json()
def has_answer(t):
if "results" in t and len(t["results"]["bindings"]) > 0:
return True
if "boolean" in t:
return True
return False
if __name__ == "__main__":
with open('data/LC-QUAD/train-data.json', 'r', encoding='utf-8') as f:
train = json.load(f)
with open('data/LC-QUAD/test-data.json', 'r', encoding='utf-8') as f:
test = json.load(f)
data = train + test
print('data len: ', len(data))
with open("data/LC-QUAD/data.json", "w") as write_file:
json.dump(data, write_file)
ds = LC_Qaud(path="./data/LC-QUAD/data.json")
tmp = []
for qapair in prepare_dataset(ds).qapairs:
raw_row = dict()
raw_row["id"] = qapair.id.__str__()
raw_row["question"] = qapair.question.text
raw_row["sparql_query"] = qapair.sparql.query
try:
r = query(qapair.sparql.query)
raw_row["answers"] = r[1]
except Exception as e:
raw_row["answers"] = []
tmp.append(raw_row)
with open('data/LC-QUAD/linked_answer.json', 'w') as jsonFile:
json.dump(tmp, jsonFile)
print('data len: ', len(tmp))