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 ・・・新着記事一覧を見る

構成比を合計しても100%にならないと言われた…|ツイッター出題回答 (2022-09-01)
一覧から複数条件(部分一致、範囲)に合致するデータを抽出する|ツイッター出題回答 (2022-08-30)
縦横スピルしないXLOOKUP代替(MATCH+INDEX,FILTER,CHOOSEROWS)|エクセル入門(2022-08-27)
IF関数の論理式で比較演算子を省略したCOUNT系関数を書くのは|ツイッター出題回答 (2022-08-23)
LAMBDA以降の新関数の使用例|エクセル入門(2022-08-22)
数珠順列(配置に条件付き)を全て出力する|ツイッター出題回答 (2022-08-20)
日付時刻のマイナス表示に対応する方法|ツイッター出題回答 (2022-08-17)
LAMBDA以降の新関数について|エクセル入門(2022-08-16)
条件付きの最大値と中央値("A"が2文字の条件)|ツイッター出題回答 (2022-08-14)
VBAマクロと操作対象データの分離について|ツイッター出題回答 (2022-08-11)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.繰り返し処理(For Next)|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.Excelショートカットキー一覧|Excelリファレンス
7.並べ替え(Sort)|VBA入門
8.マクロって何?VBAって何?|VBA入門
9.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
10.エクセルVBAでのシート指定方法|VBA技術解説




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


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



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