ZETA-A / node-mecab-ko-ts

Yet another mecab wrapper for nodejs
0 stars 0 forks source link

mecab-ko-ts

Table of Content

About

KOREAN README.md

mecab-ko-ts is an updated version of mecab-ya.
The TypeScript support and Sync feature have been updated.

Yet another mecab wrapper for nodejs and the main purpose is easy to use.
Mecab is a morphological analyzer for Japanease language.
And you can use this for Korean language with mecab-ko.

Install

$ npm install mecab-ko-ts

Requirements

You need mecab or mecab-ko for Korean language.

If you don't have mecab yet, you can install with the prepared script.

$ node_modules/mecab-ko-ts/bin/install-mecab

For the Korean language.

$ node_modules/mecab-ko-ts/bin/install-mecab ko

Usage

mecab-ko-ts use the mecab library in the node_modules/mecab-ko-ts/mecab directory.

But, you can set a mecab library path like below.

MECAB_LIB_PATH=/usr/local/lib node index.js

OR

MECAB_LIB_PATH=/usr/local/lib/mecab-ko node index.js

So, you can select a mecab library for specific language when you use this and you can distribute this as a builtin library for AWS Lambda like that.

Examples

JavaScript

var mecab = require("mecab-ko-ts");

var text = "아버지가방에들어가신다";

mecab.pos(text, function (err, result) {
    console.log(result);
    /*
        [ [ '아버지', 'NNG' ],
          [ '가', 'JKS' ],
          [ '방', 'NNG' ],
          [ '에', 'JKB' ],
          [ '들어가', 'VV' ],
          [ '신다', 'EP+EC' ] ]
    */
});

mecab.morphs(text, function (err, result) {
    console.log(result);
    /*
        [ '아버지', '가', '방', '에', '들어가', '신다' ]
    */
});

mecab.nouns(text, function (err, result) {
    console.log(result);
    /*
        [ '아버지', '방' ]
    */
});

mecab.all(text, function (err, result) {
    console.log(result);
    /*
        [
          [
            '아버지', 'NNG',
            '*',      'F',
            '아버지', '*',
            '*',      '*',
            '*'
          ],
          [
            '가', 'JKS', '*',
            'F',  '가',  '*',
            '*',  '*',   '*'
          ],
          // ... and so on
        ]
    */
});

TypeScript

import mecab from "mecab-ko-ts";

const text = "아버지가방에들어가신다";

mecab.pos(text, function (err, result) {
    console.log(result);
    /*
        [ [ '아버지', 'NNG' ],
          [ '가', 'JKS' ],
          [ '방', 'NNG' ],
          [ '에', 'JKB' ],
          [ '들어가', 'VV' ],
          [ '신다', 'EP+EC' ] ]
    */
});

mecab.morphs(text, function (err, result) {
    console.log(result);
    /*
        [ '아버지', '가', '방', '에', '들어가', '신다' ]
    */
});

mecab.nouns(text, function (err, result) {
    console.log(result);
    /*
        [ '아버지', '방' ]
    */
});

mecab.all(text, function (err, result) {
    console.log(result);
    /*
        [
          [
            '아버지', 'NNG',
            '*',      'F',
            '아버지', '*',
            '*',      '*',
            '*'
          ],
          [
            '가', 'JKS', '*',
            'F',  '가',  '*',
            '*',  '*',   '*'
          ],
          // ... and so on
        ]
    */
});

Sync

Synchronous versions are also available (just add 'Sync' to the function name)

/*
    Example
*/
const mecab = require("mecab");

console.log(mecab.posSync("아버지가방에들어가신다"));
/*
        [ [ '아버지', 'NNG' ],
          [ '가', 'JKS' ],
          [ '방', 'NNG' ],
          [ '에', 'JKB' ],
          [ '들어가', 'VV' ],
          [ '신다', 'EP+EC' ] ]
    */

You can find out a simple example on node-mecab-ya-example

License

MIT License