mirror of https://github.com/explosion/spaCy.git
74 lines
2.4 KiB
Python
74 lines
2.4 KiB
Python
|
# coding: utf8
|
|||
|
from __future__ import unicode_literals
|
|||
|
|
|||
|
from .tokenizer_exceptions import TOKENIZER_EXCEPTIONS
|
|||
|
from .stop_words import STOP_WORDS
|
|||
|
from .lex_attrs import LEX_ATTRS
|
|||
|
|
|||
|
# uncomment if files are available
|
|||
|
# from .norm_exceptions import NORM_EXCEPTIONS
|
|||
|
from .tag_map import TAG_MAP
|
|||
|
# from .morph_rules import MORPH_RULES
|
|||
|
|
|||
|
# uncomment if lookup-based lemmatizer is available
|
|||
|
from .lemmatizer import LOOKUP
|
|||
|
# from ...lemmatizerlookup import Lemmatizer
|
|||
|
|
|||
|
from .tokenizer_exceptions import TOKENIZER_EXCEPTIONS
|
|||
|
from ..tokenizer_exceptions import BASE_EXCEPTIONS
|
|||
|
from ..norm_exceptions import BASE_NORMS
|
|||
|
from ...language import Language
|
|||
|
from ...attrs import LANG, NORM
|
|||
|
from ...util import update_exc, add_lookups
|
|||
|
|
|||
|
def _return_tl(_):
|
|||
|
return 'tl'
|
|||
|
|
|||
|
|
|||
|
# Create a Language subclass
|
|||
|
# Documentation: https://spacy.io/docs/usage/adding-languages
|
|||
|
|
|||
|
# This file should be placed in spacy/lang/xx (ISO code of language).
|
|||
|
# Before submitting a pull request, make sure the remove all comments from the
|
|||
|
# language data files, and run at least the basic tokenizer tests. Simply add the
|
|||
|
# language ID to the list of languages in spacy/tests/conftest.py to include it
|
|||
|
# in the basic tokenizer sanity tests. You can optionally add a fixture for the
|
|||
|
# language's tokenizer and add more specific tests. For more info, see the
|
|||
|
# tests documentation: https://github.com/explosion/spaCy/tree/master/spacy/tests
|
|||
|
|
|||
|
|
|||
|
class TagalogDefaults(Language.Defaults):
|
|||
|
lex_attr_getters = dict(Language.Defaults.lex_attr_getters)
|
|||
|
lex_attr_getters[LANG] = _return_tl # ISO code
|
|||
|
# add more norm exception dictionaries here
|
|||
|
lex_attr_getters[NORM] = add_lookups(Language.Defaults.lex_attr_getters[NORM], BASE_NORMS)
|
|||
|
|
|||
|
# overwrite functions for lexical attributes
|
|||
|
lex_attr_getters.update(LEX_ATTRS)
|
|||
|
|
|||
|
# add custom tokenizer exceptions to base exceptions
|
|||
|
tokenizer_exceptions = update_exc(BASE_EXCEPTIONS, TOKENIZER_EXCEPTIONS)
|
|||
|
|
|||
|
# add stop words
|
|||
|
stop_words = STOP_WORDS
|
|||
|
|
|||
|
# if available: add tag map
|
|||
|
# tag_map = dict(TAG_MAP)
|
|||
|
|
|||
|
# if available: add morph rules
|
|||
|
# morph_rules = dict(MORPH_RULES)
|
|||
|
|
|||
|
# if available: add lookup lemmatizer
|
|||
|
# @classmethod
|
|||
|
# def create_lemmatizer(cls, nlp=None):
|
|||
|
# return Lemmatizer(LOOKUP)
|
|||
|
|
|||
|
|
|||
|
class Tagalog(Language):
|
|||
|
lang = 'tl' # ISO code
|
|||
|
Defaults = TagalogDefaults # set Defaults to custom language defaults
|
|||
|
|
|||
|
|
|||
|
# set default export – this allows the language class to be lazy-loaded
|
|||
|
__all__ = ['Tagalog']
|