2 releases

0.38.4 Dec 6, 2024
0.38.2 Dec 6, 2024

#2141 in Text processing

Download history 283/week @ 2024-12-04 23/week @ 2024-12-11

306 downloads per month

MIT license

130KB
441 lines

lindera-py

Python binding for Lindera, a Japanese morphological analysis engine.

Install project dependencies

Install Python

# Install Python
% pyenv install 3.12.3

Setup repository and activate virtual environment

# Clone lindera-py project repository
% git clone git@github.com:lindera/lindera-py.git
% cd lindera-py

# Set Python version for this project
% pyenv local 3.12.3

# Make Python virtual environment
% python -m venv .venv

# Activate Python virtual environment
% source .venv/bin/activate

# Initialize lindera-py project
(.venv) % make init

Install lindera-py as a library in the virtual environment

This command takes a long time because it builds a library that includes all the dictionaries.

(.venv) % make maturin-develop

Example code

from lindera_py import Segmenter, Tokenizer, load_dictionary


def main():
    # load the dictionary
    dictionary = load_dictionary("ipadic")

    # create a segmenter
    segmenter = Segmenter("normal", dictionary)

    # create a tokenizer
    tokenizer = Tokenizer(segmenter)

    text = "関西国際空港限定トートバッグを東京スカイツリーの最寄り駅であるとうきょうスカイツリー駅で買う"
    print(f"text: {text}\n")

    # tokenize the text
    tokens = tokenizer.tokenize(text)

    for token in tokens:
        print(token.text)


if __name__ == "__main__":
    main()

Dependencies

~21–37MB
~676K SLoC