Word MVPの新田さんが書かれた以下の記事を見て思いついたマクロです。
・ユーザー登録をしたキーボードのショートカットを書き出すマクロ
・ユーザー登録をしたキーボードのショートカットを書き出すマクロ(その2)
・ユーザー登録をしたキーボードのショートカットを印刷する方法
下記「OutPutKeyBindings」を実行すると、標準テンプレート含めたテンプレートファイル(有効になっているもののみ)に登録されているキー定義一覧をCSVファイルとしてデスクトップに出力します。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 | Option Explicit Public Sub OutPutKeyBindings() 'キー定義出力 Dim OutputFilePath As String Dim tp As Word.Template Dim tmp As Word.Template Dim kb As Word.KeyBinding Dim ff As Integer '出力先ファイル準備(デスクトップにCSVファイルとして出力) OutputFilePath = CreateObject( "WScript.Shell" ).SpecialFolders( "Desktop" ) & _ Application.PathSeparator & "WordKeyBindings.csv" ff = FreeFile Open OutputFilePath For Output As #ff Print #ff, "テンプレート名,テンプレートのパス,コマンド,キーコード,キーの組み合わせ" Set tmp = Application.CustomizationContext '現在の保存先テンプレート取得 '標準テンプレート Application.CustomizationContext = NormalTemplate For Each kb In Application.KeyBindings Print #ff, "標準テンプレート(" & NormalTemplate.Name & ")," & _ NormalTemplate.FullName & "," & _ kb.Command & "," & _ kb.KeyCode & "," & _ kb.KeyString Next '標準テンプレート以外 For Each tp In Application.Templates If tp.FullName <> NormalTemplate.FullName Then If IsInstalledTemplate(tp) = True Then Application.CustomizationContext = tp For Each kb In Application.KeyBindings Print #ff, tp.Name & "," & _ tp.FullName & "," & _ kb.Command & "," & _ kb.KeyCode & "," & _ kb.KeyString Next End If End If Next Application.CustomizationContext = tmp '保存先テンプレートを元に戻す Set tmp = Nothing Close #ff MsgBox "処理が終了しました。" & vbCrLf & vbCrLf & _ "[" & OutputFilePath & "]" & vbCrLf & vbCrLf & _ "にキー定義一覧が出力されました。" , vbInformation + vbSystemModal End Sub Private Function IsInstalledTemplate( ByVal tp As Word.Template) As Boolean 'テンプレートが有効になっているかどうかを判断 Dim ad As Word.AddIn Dim ret As Boolean ret = False '初期化 '標準テンプレートであればTrue If tp.FullName = NormalTemplate.FullName Then ret = True Else On Error Resume Next Set ad = Application.AddIns(tp.FullName) On Error GoTo 0 If Not ad Is Nothing Then 'Wordアドインライブラリ(WLL)ではない = テンプレートの場合のみ処理 If ad.Compiled = False Then If ad.Installed = True Then ret = True End If End If Set ad = Nothing End If End If IsInstalledTemplate = ret End Function |
CSVファイルとして出力しておけば、Excelやテキストエディタで自分の好きな形に加工することが容易にできます。
この記事へのコメントはありません。