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

ExcelマクロVBAの基本と応用、エクセルVBAの初級・初心者向け解説
最終更新日: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 ・・・新着記事一覧を見る

イータ縮小ラムダ(eta reduced lambda)|エクセル入門(2023-11-20)
PIVOTBY関数(縦軸と横軸でグループ化して集計)|エクセル入門(2023-11-19)
GROUPBY関数(縦軸でグループ化して集計)|エクセル入門(2023-11-18)
PY関数(Pythonコードをセル内で実行)|エクセル入門(2023-11-17)
画像「セルに配置」のVBAについて(365の新機能)|VBA技術解説(2023-11-13)
スピルのゴーストの範囲を選択するVBA|ツイッター出題回答 (2023-10-31)
エクセル試験3:月間の所定労働時間|エクセル練習問題(2023-10-04)
エクセル試験2:所得税の計算|エクセル練習問題(2023-10-04)
エクセル試験1:曜日別の平均客単価|エクセル練習問題(2023-10-04)
列全体を指定する時のRangeとColumnsの違い|ツイッター出題回答 (2023-09-24)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.繰り返し処理(For Next)|VBA入門
4.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
5.変数宣言のDimとデータ型|VBA入門
6.条件分岐(IF)|VBA入門
7.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
8.並べ替え(Sort)|VBA入門
9.マクロとは?VBAとは?VBAでできること|VBA入門
10.Range以外の指定方法(Cells,Rows,Columns)|VBA入門




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


記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。



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