
No.1ベストアンサー
- 回答日時:
通常はヘルプ表示のファンクションキーを別の事に利用する訳ですね?
では、「Application.OnKey "{F1}", "Sheet1_F1"」 は、
どこに書かれているのでしょうか?
シート?標準モジュール?
また、「Sheet1_F1」は標準モジュールに書かれたプロシージャでしょうか?
それに、書式の問題もあります。
EXCELを起動後、終了するまでキーの機能変更を有効にするには、
標準モジュールに書かれたプロシージャでなければいけません。
また、auto_openで書かなければ最初から機能しなかったと思います。
'ヘルプキー無効にする例
Sub auto_open()
Application.OnKey "{F1}", "TEST"
End Sub
Sub TEST()
MsgBox "ヘルプ無効"
End Sub
記載するのは標準モジュール1つで構いません。
上記のコードを標準モジュールにコピーして保存後、EXCELを再起動させて「F1キー」を押して見て下さい。
(マクロを有効にするのをお忘れ無く)
今回の場合は、Application.OnKey "{F1}", "Sheet1_F1" ですが・・・
auto_open()というサブプロシジャーは、エクセル起動時に実行が予約されている名前で、
VBAとしてはブックが開かれた時、一度だけ実行します。
エクセル本来の機能に戻すには、
Application.Onkey "{F1}"
と、プロシージャの部分を省略すると、エクセルの通常の機能へ戻るのですが、
面倒であれば、そのままエクセル自体を終了すれば問題ありません。
ただし、上記VBAを含むブックを読み込んだエクセル自体を終了せずに、
VBAを含まない、別のブックを読み込んでも機能はキャンセルされませんので注意が必要です。
'ブックのみを閉じる時、ヘルプキーを有効にする例
Sub auto_close()
Application.OnKey "{F1}"
End Sub
上記はブックを閉じる時ですが、考え方は、auto_open()と同じです。
auto_open、auto_close は、特定のブックで初期設定や自動保存など
便利に使える(正常起動、正常終了の場合ですが)ものですが、
扱いには注意して下さい。
さわらなくて良いメニューまで非表示にしてしまった経験者です(^^;;
この回答への補足
Application.OnKey "{F1}", "Sheet1_F1"
は、auto_open() に記述しています。
説明がわかりづらかったようです。
[Tab][Enter]で各項目に移動した直後は [F1] を押すと、Sheet1_F1 を実行するのですが、各項目上で入力途中で("1"と入力した直後に) [F1] を押すと、なぜか、ヘルプが起動してしまうのです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excel VBAで、ユーザーフォーム...
-
Excel VBAでリンク切れをチェッ...
-
ユーザー定義関数に#NAME?が返...
-
エクセルVBAでシートモジュール...
-
VBAProjectのモジュ...
-
Excelで時刻になったら知らせて...
-
EXECEL VBA コマンドボタンか...
-
モジュールとクラスの違いって...
-
VBAのモジュールについて教えて...
-
GetCursorInfoの使い方
-
Excel VBA 定義されたプロージ...
-
ユーザーフォーム上に表示され...
-
インストールされているモジュ...
-
ArduinoのジャイロモジュールMP...
-
気のせいでしょうか?
-
Excel VBA 『Call』で呼び出す...
-
ユーザー定義関数をEXCELに常駐...
-
クラスモジュールについて
-
モジュールの最大数はいくつな...
-
Access VBA標準モジュールにつ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel VBAでリンク切れをチェッ...
-
エクセルVBAでシートモジュール...
-
VBでグローバル変数を宣言するには
-
ユーザー定義関数に#NAME?が返...
-
Excel VBAで、ユーザーフォーム...
-
Excel VBA 定義されたプロージ...
-
vba userFormのSubを標準モジュ...
-
標準モジュールを削除したい。(...
-
'Range'メソッドは失敗しました
-
VBAで別モジュールへの変数の受...
-
モジュールからフォームのボタ...
-
モジュールの最大数はいくつな...
-
グラフのX,Y座標を取得したい
-
モジュールとクラスの違いって...
-
【vba】フォームに書いてあ...
-
Form間の値の渡し方
-
VBのフォームモジュールと標準...
-
VBA モジュールで共通に使う変...
-
Excel VBA 『Call』で呼び出す...
-
acwzlibとは?
おすすめ情報