* Handle string paths in default_vocab, default_parser, default_entity in Language class

This commit is contained in:
Matthew Honnibal 2016-01-18 22:37:24 +01:00
parent e825fd9554
commit bba0a5e078
1 changed files with 16 additions and 3 deletions

View File

@ -140,19 +140,32 @@ class Language(object):
def default_vocab(cls, package, get_lex_attr=None): def default_vocab(cls, package, get_lex_attr=None):
if get_lex_attr is None: if get_lex_attr is None:
get_lex_attr = cls.default_lex_attrs() get_lex_attr = cls.default_lex_attrs()
if hasattr(package, 'dir_path'):
return Vocab.from_package(package, get_lex_attr=get_lex_attr) return Vocab.from_package(package, get_lex_attr=get_lex_attr)
else:
return Vocab.load(package, get_lex_attr)
@classmethod @classmethod
def default_parser(cls, package, vocab): def default_parser(cls, package, vocab):
if hasattr(package, 'dir_path'):
data_dir = package.dir_path('deps') data_dir = package.dir_path('deps')
else:
data_dir = package
if data_dir and path.exists(data_dir): if data_dir and path.exists(data_dir):
return Parser.from_dir(data_dir, vocab.strings, ArcEager) return Parser.from_dir(data_dir, vocab.strings, ArcEager)
else:
return None
@classmethod @classmethod
def default_entity(cls, package, vocab): def default_entity(cls, package, vocab):
if hasattr(package, 'dir_path'):
data_dir = package.dir_path('ner') data_dir = package.dir_path('ner')
else:
data_dir = package
if data_dir and path.exists(data_dir): if data_dir and path.exists(data_dir):
return Parser.from_dir(data_dir, vocab.strings, BiluoPushDown) return Parser.from_dir(data_dir, vocab.strings, BiluoPushDown)
else:
return None
def __init__(self, def __init__(self,
data_dir=None, data_dir=None,