-
Notifications
You must be signed in to change notification settings - Fork 373
/
Copy pathsolution_03_12.py
38 lines (28 loc) · 1.38 KB
/
solution_03_12.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
import json
import spacy
from spacy.language import Language
from spacy.tokens import Span
from spacy.matcher import PhraseMatcher
with open("exercises/ja/countries.json", encoding="utf8") as f:
COUNTRIES = json.loads(f.read())
with open("exercises/ja/capitals.json", encoding="utf8") as f:
CAPITALS = json.loads(f.read())
nlp = spacy.blank("ja")
matcher = PhraseMatcher(nlp.vocab)
matcher.add("COUNTRY", list(nlp.pipe(COUNTRIES)))
@Language.component("countries_component")
def countries_component_function(doc):
# すべてのマッチ結果に対して、「GPE」ラベルが付いたスパンを作成しましょう
matches = matcher(doc)
doc.ents = [Span(doc, start, end, label="GPE") for match_id, start, end in matches]
return doc
# パイプラインにコンポーネントを追加しましょう
nlp.add_pipe("countries_component")
print(nlp.pipe_names)
# 国の首都名が入った辞書をスパンのテキストで引くゲッター
get_capital = lambda span: CAPITALS.get(span.text)
# get_capitalをスパンの拡張属性「capital」に登録
Span.set_extension("capital", getter=get_capital)
# テキストを処理し、固有表現テキスト、ラベル、capital属性を表示
doc = nlp("チェコ共和国はスロバキアが領空を守るのを手助けするかもしれない。")
print([(ent.text, ent.label_, ent._.capital) for ent in doc.ents])