mirror of
https://github.com/explosion/spaCy.git
synced 2025-01-15 03:56:23 +03:00
66f8f9d4a0
JapaneseTokenizer now returns a Doc, not individual words
40 lines
1.1 KiB
Python
40 lines
1.1 KiB
Python
# encoding: utf8
|
|
from __future__ import unicode_literals, print_function
|
|
|
|
from ...language import Language
|
|
from ...attrs import LANG
|
|
from ...tokens import Doc
|
|
from ...tokenizer import Tokenizer
|
|
|
|
|
|
class JapaneseTokenizer(object):
|
|
def __init__(self, cls, nlp=None):
|
|
self.vocab = nlp.vocab if nlp is not None else cls.create_vocab(nlp)
|
|
try:
|
|
from janome.tokenizer import Tokenizer
|
|
except ImportError:
|
|
raise ImportError("The Japanese tokenizer requires the Janome "
|
|
"library: https://github.com/mocobeta/janome")
|
|
self.tokenizer = Tokenizer()
|
|
|
|
def __call__(self, text):
|
|
words = [x.surface for x in self.tokenizer.tokenize(text)]
|
|
return Doc(self.vocab, words=words, spaces=[False]*len(words))
|
|
|
|
|
|
class JapaneseDefaults(Language.Defaults):
|
|
@classmethod
|
|
def create_tokenizer(cls, nlp=None):
|
|
return JapaneseTokenizer(cls, nlp)
|
|
|
|
|
|
class Japanese(Language):
|
|
lang = 'ja'
|
|
Defaults = JapaneseDefaults
|
|
|
|
def make_doc(self, text):
|
|
return self.tokenizer(text)
|
|
|
|
|
|
__all__ = ['Japanese']
|