import jsgf book_grammar = jsgf.parse_grammar_file('pullrequest.jsgf') def get_dialog_act(rule): slots = [] get_slots(rule.expansion, slots) return {'act': rule.grammar.name, 'slots': slots} def get_slots(expansion, slots): if expansion.tag != '': slots.append((expansion.tag, expansion.current_match)) return for child in expansion.children: get_slots(child, slots) if not expansion.children and isinstance(expansion, jsgf.NamedRuleRef): get_slots(expansion.referenced_rule.expansion, slots) def nlu(utterance): matched = book_grammar.find_matching_rules(utterance) if matched: return get_dialog_act(matched[0]) else: return {'act': 'null', 'slots': []} #result = nlu('jakie są dostępne funkcje') #result = nlu('w czym możesz mi pomóc') result = nlu('jakie są nowe pull requesty') #result = nlu('ile jest nowych pull requestów') print(result)