【Python】漢字を分解するライブラリを使ってみた【部首分解】

公開日: : 最終更新日:2021/03/08 Python , , , ,

Python で漢字を部首やさらに細かい部分に分解してくれるライブラリがあったので使ってみました。

このライブラリを使うと、ある漢字を与えると、その漢字を自動的に分解して部首(偏・旁・冠)や部分をリスト形式で返してくれます。

kanjivg-radical というライブラリで、以下のURLからダウンロードし、解凍します。

https://github.com/yagays/kanjivg-radical

Contents

json 形式のファイル読み込む

kanjivg-radical では json 形式のファイルを読み込むため、以下のような関数を用意します。

kanjivg-radical の特徴

このライブラリでできることは、大きく分けて以下の2つがあります。

  • 漢字を部分(部首など)に分解する
  • 部分(部首など)を含む漢字を抽出する

それぞれいくつか細かい特徴が異なる関数が用意されています。

漢字を部分(部首など)に分解する系

これは、「kanji2xxxx」となっている関数が該当します。

基本的に漢字を1文字与えると分解したものをリストで返します。

それぞれ使い方と結果を示します。

kanji2radical

文字を一回だけ分解します。

結果は以下のようになります。

[‘石’, ‘少’]

kanji2element

文字を再帰的に分解していきます。

結果をみると、kanji2radical と比較して、細かく分解されていることが分かると思います。

[‘石’, ‘丿’, ‘少’, ‘口’, ‘小’]

kanji2radical_left_right

文字を「偏」と「旁」に分解します。「偏」と「旁」に分解できない漢字についてはエラーとなります。

結果は以下のとおり。

[‘石’, ‘少’]

kanji2radical_top_buttom

文字を「冠」と「脚」に分解します。「冠」と「脚」に分解できない漢字についてはエラーとなります。

結果は以下のとおり。

[‘少’, ‘目’]

部分(部首など)を含む漢字を抽出する系

これは、「xxxx2kanji」となっている関数が該当します。

部分を与えると、それが含まれる漢字をリストで返します。

それぞれ、コードと結果のみを以下に示します。

radical2kanji

[‘尠’, ‘沙’, ‘鈔’, ‘抄’, ‘眇’, ‘秒’, ‘省’, ‘劣’, ‘杪’, ‘紗’, ‘雀’, ‘歩’, ‘賓’, ‘炒’, ‘隲’, ‘毟’, ‘妙’, ‘砂’]

element2kanji

[‘尠’, ‘瀕’, ‘沙’, ‘鈔’, ‘濱’, ‘抄’, ‘鯊’, ‘頻’, ‘鬢’, ‘捗’, ‘眇’, ‘秒’, ‘殯’, ‘省’, ‘擯’, ‘莎’, ‘劣’, ‘嬪’, ‘渉’, ‘裟’, ‘杪’, ‘紗’, ‘雀’, ‘渺’, ‘顰’, ‘歩’, ‘賓’, ‘炒’, ‘繽’, ‘陟’, ‘蘋’, ‘緲’, ‘隲’, ‘毟’, ‘妙’, ‘檳’, ‘砂’, ‘娑’]

radical2kanji_left_right

[‘尠’, ‘沙’, ‘鈔’, ‘抄’, ‘眇’, ‘秒’, ‘杪’, ‘紗’, ‘炒’, ‘妙’, ‘砂’]

関連記事

【Python】 複数の辞書型の同じ key を持つ value を計算に用いる方法。

Python で、複数の辞書型を読み込んで、同じキー(key)を持つ数値(value)を計算に使う方

記事を読む

【Python】OpenCV を使って顔画像を検出してみた。

OpenCV のインストール Numpy のインストール [crayon-6694e1557

記事を読む

【Python】Requests ライブラリを使って Web ページを取得してみた。

python の標準ライブラリ urllib を使っても Web ページの取得はできるのですが、Re

記事を読む

【Atomエディタ】Python 開発用にインストールしてみた。

Python でプログラミングするときの エディタ を探していたのですが、とりあえず Atom とい

記事を読む

【Python】 Series 型を dict(辞書型)に変換する方法。

Python で Series 型を dict(辞書型)に簡単に変換する方法を紹介します。 「

記事を読む

【Python】pip3 で「cannot import name ‘main’」エラーが出たときの対処法。

Python でライブラリをインストールする際に、pipを使います。 Python2 と Py

記事を読む

【OpenCV】画像の顔部分を検出する方法【Python】

OpenCV を使って、Python で画像から顔部分の検出を行ったときのメモです。 Anac

記事を読む

【Pandas】 DataFrame で2行の列ごとの差を計算する方法【Python】

今回は、Pandas の DataFrame で、2行間の列ごとの値の差を計算し、その結果を Dat

記事を読む

【Pandas】 loc・ilocで1行のみ Series ではなく DataFrame で抽出する方法。

Python の Pandas で DataFrame から loc や iloc を使って行を抽出

記事を読む

【OpenCV】検出した顔画像部分を切り出す方法【Python】

OpenCV を使って、Python で画像の中から顔部分を切り出したときのメモです。 顔部分

記事を読む

無料動画編集ソフト AviUtl で mp4 形式の動画を読み込み・出力する方法【Windows】

今回は、無料動画編集ソフト AviUtl で mp4 形式の動画を読み

【Cubase】イヤホンから音がでないときの対処方法。

Cubase でイヤホンから音がでなくなったときの対処方法のメモです。

【Cubase】特定のトラックを無効にする方法。

今回は、Cubaseで特定のトラックのみを無効にする方法について紹介し

【転移学習】学習済みVGG16 による転移学習を行う方法【PyTorch】

今回は、PyTorch を使って、学習済みのモデル VGG16 を用い

【PyTorch】畳込みニューラルネットワークを構築する方法【CNN】

今回は、PyTorch を使って畳込みニューラルネットワーク(CNN)

→もっと見る

PAGE TOP ↑