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

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

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

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

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

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

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】プログレスバーを表示させる【tqdm】

Python でスクリプトの実行時間が長くなると、進捗状況が知りたくなったので、標準出力にどのくらい

記事を読む

【Linux】 ローカルに Python をインストールする方法。

今回は、Linux サーバに、root 権限なしで、ローカルに Python をインストールした方法

記事を読む

【Pandas】 DetaFrame の列ごとに演算する方法【Python】

今回は、DetaFrame の列ごとに平均や加算・減算なのど演算をし、結果を DetaFrame 型

記事を読む

【Pandas】 DataFrame のインデックスを置き換える方法【Python】

今回は、Pandas の DataFrame型で、インデックス(index)を分かりやすいものに置き

記事を読む

【Python】 DataFrame の特定の列で出現回数をカウントして降順でソートする方法。

Python で DataFrame 型の特定の列を指定して、対象列の文字列の出現回数をカウントして

記事を読む

【Pandas】 DataFrame のある列の最大値を含む行のインデックス値を取得する方法。

今回は、Pandas の DataFrame において、ある列で最大値を求めて、その最大値をもつ行に

記事を読む

【Pandas】 DataFrame と Series のデータ構造について【Python】

今回は、Python でデータ分析を行っていると必ず使う Pandas の DataFrame と

記事を読む

【Python】時系列データ(為替データ)をグラフ表示してみた。

今回は、pandas・matplotlib ライブラリを使って、時系列データ(為替データ)をグラフ表

記事を読む

【Python】Beautiful Soup を使ってスクレイピングする方法。

Beautiful Soup は、シンプルでわかりやすい API でデータを抜き出せる Python

記事を読む

【Python】API を使って Amazon の商品情報を収集する方法。

AmazonAPI ライブラリをインストール 以下のコマンドで python-amazon-sim

記事を読む

【TensorFlow】GPUを認識しない時の対処方法【Python】

TensorFlow で GPU を認識させようとしたときにハマってし

【耳コピ】音楽ファイルを楽器ごとに分離する方法【Spleeter:フリー】

今回は、mp3 などの音楽ファイルをボーカル、ベース、ドラムなどの楽器

【Chainer】手書き数字認識をしてみた【Deep Learning】

Chainerを用いて、ニューラルネットワークを構築し、手書き数字認識

【Spyder】引数のあるスクリプトを実行する方法。

Python の統合開発環境(IDE)である Spyder では、簡単

【Anaconda】Prompt 上で Git コマンドを実行する方法。

Anaconda のコマンドプロンプト(Anaconda Prompt

→もっと見る

PAGE TOP ↑