Static memory-efficient Trie-like structures for Python (3.7+) based on marisa-trie C++ library.
String data in a MARISA-trie may take up to 50x-100x less memory than in a standard Python dict; the raw lookup speed is comparable; trie also provides fast advanced methods like prefix search.
Note
There are official SWIG-based Python bindings included in C++ library distribution; this package provides alternative Cython-based pip-installable Python bindings.
python -m pip install -U marisa-trie
See tutorial and API for details.
- The library is not tested with mingw32 compiler;
.prefixes()
method ofBytesTrie
andRecordTrie
is quite slow and doesn't have iterator counterpart;read()
andwrite()
methods don't work with file-like objects (they work only with real files; pickling works fine for file-like objects);- there are
keys()
anditems()
methods but novalues()
method.
Wrapper code is licensed under MIT License.
Bundled marisa-trie C++ library is dual-licensed under LGPL and BSD 2-clause license.