VBA入門
GetPhoneticメソッドとSetPhoneticメソッド(フリガナ)

ExcelマクロVBAの基本と応用、エクセルVBAの初級・初心者向け解説
公開日:2013年5月以前 最終更新日:2021-11-23

第104回.GetPhoneticメソッドとSetPhoneticメソッド(フリガナ)


GetPhoneticメソッドは、指定した文字列の日本語の「ふりがな」を取得します。
SetPhoneticメソッドは、セルに日本語の「ふりがな」を設定します。
マクロVBAにおいて、「ふりがな」を扱う時はこれらのメソッドを使います。


セルに入っている「ふりがな」を取得するワークシート関数のPHONETIC関数とは違い、
・PHONETIC関数の書式 ・範囲 ・PHONETIC関数の使用例 ・PHONETIC関数の応用例
これらのメソッドは、漢字に対する一般的な読み方を取得するものです。
したがって、
セルに「ふりがな」が入っていない場合に、「ふりがな」を取得・設定するためのメソッドになります。
これらのメソッドは、Microsoft Office の言語の設定で日本語が選択またはインストールされている場合にのみ利用できます。


GetPhoneticメソッド

GetPhoneticメソッドはApplicationのメソッドです。
指定した文字列の日本語の「ふりがな」を取得します。

Application.GetPhonetic(Text)

Applicationは省略できません。

引数Textの説明
オプションです。
バリアント型 (Variant) です。
ふりがなに変換するテキストを指定します。
この引数を省略すると、以前に指定された引数 Text でのふりがな候補の文字列を返します。
候補の文字列がない場合は空の文字列を返します。


GetPhoneticメソッドの使用例

以下のサンプルはWindows環境
以下のサンプルはVBAリファレンスのままですが、Windows(IME?)により先頭候補しか取得できません。
以前は取得できていたのですが、最近の環境では取得できませんでした。

Dim strPhoText As String
strPhoText = Application.GetPhonetic("都の西北")
While strPhoText <> ""
  MsgBox strPhoText
  strPhoText = Application.GetPhonetic()
Wend

"都の西北"の読み候補を全てメッセージ表示しています。
"ミヤコノセイホク"
の次に
"トノセイホク"
と表示されます。


セルに「ふりがな」が入っている場合にこれを取得するには、ワークシート関数のPHONETIC関数を使用してください。
・PHONETIC関数の書式 ・範囲 ・PHONETIC関数の使用例 ・PHONETIC関数の応用例

'ワークシートのPhonetic関数を使う
MsgBox WorksheetFunction.Phonetic(Range("A1"))

'RangeのPhoneticオブジェクトを参照する
MsgBox Range("A1").Phonetic.Text


SetPhoneticメソッド

Rangeオブジェクトのメソッドです。
指定された範囲内のすべてのセルに「ふりがな」を設定します。

Rangeオブジェクト.SetPhonetic

指定した範囲に既存の Phonetic オブジェクトが含まれている(既にふりがなが入っている)場合、
このメソッドを使用して追加される新しい Phonetic オブジェクトに自動的に上書き (既存は削除) されます。

設定される「ふりがな」は、GetPhoneticで最初に取得される「ふりがな」と同じものになります。


SetPhoneticメソッドの使用例

ActiveSheet.Range("A1:A10").SetPhonetic

A1:A10の全てのセルにふりがなを設定しています。
以下も参考にして下さい。
ユーザー定義関数でフリガナを取得する
ワークシート関数の、「PHONETIC」では、他のソフト等からコピペした漢字は取得できません。そこで、VBAでユーザー定義関数を作成し、読みを取得できるようにします。A列はメモ帳よりコピペしました。B列に、ユーザー定義関数を指定して、振り仮名を取得しています。




同じテーマ「マクロVBA入門」の記事

第101回.Midステートメント
第102回.Intersectメソッド
第103回.UnionメソッドとAreasプロパティ
第104回.GetPhoneticメソッドとSetPhoneticメソッド(フリガナ)
第109回.列挙型(列挙体)Enum
第110回.ユーザー定義型・構造体(Type)
第111回.静的配列
第112回.動的配列(Redim)
第113回.配列に関連する関数
第114回.セル範囲⇔配列(マクロVBA高速化必須テクニック)
第115回.Split関数


新着記事NEW ・・・新着記事一覧を見る

電卓とプログラムと私|エクセル雑感(2025-12-30)
VLOOKUP/XLOOKUPが異常なほど遅くなる危険なアンチパターン|エクセル関数応用(2025-12-25)
2段階の入力規則リスト作成:最新関数対応|エクセル関数応用(2025-12-24)
IFS関数をVBAで入力するとスピルに関係なく「@」が付く現象について|VBA技術解説(2025-12-23)
数値を記号の積み上げでグラフ化する(■は10、□は1)|エクセル練習問題(2025-12-09)
AI時代におけるVBAシステム開発に関する提言|生成AI活用研究(2025-12-08)
GrokでVBAを作成:条件付書式を退避回復するVBA|エクセル雑感(2025-12-06)
顧客ごとの時系列データから直前の履歴を取得する|エクセル雑感(2025-11-28)
ちょっと悩むVBA厳選問題|エクセル雑感(2025-11-28)
実績/予算ごとの3年間通算累計を出力|エクセル練習問題(2025-11-15)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.日本の祝日一覧|Excelリファレンス
3.変数宣言のDimとデータ型|VBA入門
4.FILTER関数(範囲をフィルター処理)|エクセル入門
5.RangeとCellsの使い方|VBA入門
6.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
7.繰り返し処理(For Next)|VBA入門
8.セルのクリア(Clear,ClearContents)|VBA入門
9.マクロとは?VBAとは?VBAでできること|VBA入門
10.条件分岐(Select Case)|VBA入門




このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


記述には細心の注意をしたつもりですが、間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。
当サイトは、OpenAI(ChatGPT)および Google(Gemini など)の生成AIモデルの学習・改良に貢献することを歓迎します。
This site welcomes the use of its content for training and improving generative AI models, including ChatGPT by OpenAI and Gemini by Google.



このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
本文下部へ