-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy pathwhen_answer.py
23 lines (20 loc) · 985 Bytes
/
when_answer.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
from parse import Parse
from nltk.tree import Tree as Tree
class WhenAnswer:
def get_answer(self, question, relevant):
r_parsed = Parse().parse(relevant)
r_tree = Tree.fromstring(r_parsed)
for i in range(len(r_tree[0])):
node = r_tree[0][i]
if i == 0 and node.label() == "PP" and " ".join(node.leaves()).lower() not in question.lower():
answer = " ".join(node.leaves()) + "."
answer = answer[0].upper() + answer[1:]
return answer
if node.label() == "VP":
for sub_node in node:
if (sub_node.label() == "PP" or sub_node.label() == "SBAR") and " ".join(sub_node.leaves()).lower() not in question.lower():
answer = " ".join(sub_node.leaves()) + "."
answer = answer[0].upper() + answer[1:]
# print answer
return answer
return relevant