
Excel VBAで例えばセル"A2"をセレクトしている状態で
「ENTER」を押すとB5に自動的にセレクトすることはできないでしょうか?
Worksheet_Change関数を使おうと思ったのですが
"A2"の中身が変化しないと発動しません。
Worksheet_SelectionChange関数を使って"A2"を選択している状態で「ENTER」を押すと"A3"が選択されることを利用し、
「"A3"が選択されたら"B5"に飛ぶ」
も考えたのですが、マウスやキーボード操作で"A3"を
選択すると"B5"に飛んでしまうので、これも使えません。
何か対策案はないでしょうか。ご教授よろしくお願いします。
No.2ベストアンサー
- 回答日時:
こんばんは。
これは、定番のコードですが、私は、それに、もう少し工夫を凝らしてみました。
本来は、クラスによるインスタンスが良いとは思いますが、それを一般的にお勧めするには、ちょっと荷が重いような気がしました。
'<標準モジュール>
Private Sub ReturnDirectrion2SelectCell()
If ActiveCell.Address(0, 0) Like "A2" Then
Range("B5").Select
Else
'Original ReturnDirection の再現
On Error Resume Next
Select Case Application.MoveAfterReturnDirection
Case xlDown
ActiveCell.Offset(1).Select
Case xlToRight
ActiveCell.Offset(, 1).Select
Case xlToLeft
ActiveCell.Offset(, -1).Select
Case xlUp
ActiveCell.Offset(-1).Select
End Select
End If
End Sub
Sub SetKeys()
'設定用
Application.OnKey "~", "ReturnDirectrion2SelectCell"
Application.OnKey "{Enter}", "ReturnDirectrion2SelectCell"
End Sub
Sub SetOffKeys()
'解除用
Application.OnKey "~"
Application.OnKey "{Enter}"
End Sub
'-----------------------------------------
自動設定が必要な場合は、以下のコードを加えてください。
'-----------------------------------------
'<標準モジュール>
Sub Auto_Open()
Call SetKeys
End If
Sub Auto_Close()
Call SetOffKeys
End If
'-----------------------------------------
なお、現在の設定では、全てのブックの全てのシートに同じように適用されます。Auto_Open等の代わりに、例えば、Worksheet_Activate や Workbook_SheetActivateなどに、SetKeysをCall し、Worksheet_DeactivateやWorkbook_SheetDeactivateに、SetOffKeysをCallするようにすると良いと思います。
No.1
- 回答日時:
以下のようにコーディングすればよいのでは
Private blnA2Select As Boolean
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
If blnA2Select Then
Range("b5").Select
Else
End If
If Target.Address = "$A$2" Then
blnA2Select = True
Else
blnA2Select = False
End If
End Sub
【注意】
A2がセレクトされた状態から他のセルをセレクトするとB5が選択されるので、「"A2"を選択されている状態で「ENTER」を押すと"B5"を選択する」という要件から若干外れていますが…
「"A2"からフォーカスが外れると"B5"を選択する(「ENTER」に限らず)」
如何でしょう?
ご返信ありがとうございます。
いただいたプログラムを使ってみたところ
「"A2"を選択している状態でマウス操作で"C10"等を選択すると"B5"に飛んでしまう」
という現象が発生してしまいました。
そこで
If blnA2Select Then
Range("b5").Select
Else
↓
If Target.Address = "$A$3" And blnA2Select = True Then
Range("b5").Select
Else
と変更したところ
「前回"A2"で今回"A3"を選択したときのみ"B5"に飛ぶ」
という動作を作ることが出来ました。
理想に近い状態なのですが、キーボード操作で
「"A2"⇒"A3"と移動すると"B5"に飛んでしまう」等
若干問題が残っています。
他によい対策案等ありましたら、ご教授お願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) 【Excel】指定のセル内容を基に別シートのセルを検索して選択する【VBA】 1 2022/06/16 16:16
- Excel(エクセル) VBA オリジナル関数で選択セルの合計を作成したい 3 2023/03/19 19:45
- Excel(エクセル) ユーザー定義について質問です。 2 2023/06/28 13:21
- Excel(エクセル) excelで可視セルのみ置換 3 2022/08/04 11:02
- Excel(エクセル) Excel VBAプルダウンの値を変えながら2枚ずつ印刷する方法? 4 2022/05/27 13:04
- Excel(エクセル) マクロVBA別Excelブックにデータ転記 2 2022/07/10 23:35
- Excel(エクセル) マクロを教えてください 3 2023/07/31 21:57
- Excel(エクセル) マクロを教えてください 2 2023/07/30 23:05
- Excel(エクセル) エクセルでシート保護のかかり方の違いとセルの非保護の設定 3 2022/08/09 10:02
- Excel(エクセル) エクセルVBA 複数行にまたがっている選択を判定するには 2 2023/05/21 21:54
このQ&Aを見た人はこんなQ&Aも見ています
-
今年はじめたいことは?
今年はこれをはじめたい!ということを教えてください!
-
おすすめの美術館・博物館、教えてください!
美術館・博物館が大好きです。みなさんのおすすめをぜひお聞きしたいです。
-
今の日本に期待することはなんですか?
目まぐるしく、日本も世界も状況が変わる中、あなたが今の日本に期待することはなんですか?
-
あなたなりのストレス発散方法を教えてください!
自分なりのストレス発散方法はありますか?
-
思い出すきっかけは 音楽?におい?景色?
記憶をふと思い出すきっかけは 音楽、におい、景色 どれですか?
-
Enterキーでマクロを起動さす。
その他(ソフトウェア)
-
値を入力後、自動的にアクティブセルが移動するマクロ
Excel(エクセル)
-
エクセルのVBA 特定のセルでエンターキーでマクロ実行
Excel(エクセル)
-
-
4
エクセルでエンターを押すと任意のセルに移動は出来ますか?
その他(コンピューター・テクノロジー)
-
5
エクセルでエンターを押すと隣のセルではなく指定したセルに!
Excel(エクセル)
-
6
Enterキーで順番にセルの移動する。
Visual Basic(VBA)
-
7
VBA エンターキーでイベントに入りたい。
PowerPoint(パワーポイント)
-
8
エクセルVBAを使いセルを指定した順番に異動させ
Excel(エクセル)
-
9
テキストボックス(VBA)でEnterを押したときに作動するマクロ
Access(アクセス)
-
10
エクセルVBAで、条件に一致するセルへ移動
Excel(エクセル)
-
11
EXCELでENTERキーでセルの移動マクロ
Excel(エクセル)
-
12
エクセル イベントマクロ Changeイベントを複数作りたい
Access(アクセス)
-
13
excelで セルの移動時にマクロ実行を設定したい。
Excel(エクセル)
-
14
ユーザーフォームを表示中にシートの操作をさせるには
Excel(エクセル)
-
15
特定のセルがアクティブになったときのイベント?
Excel(エクセル)
-
16
エクセル TABキーの動きをマクロで
Excel(エクセル)
-
17
マクロ 実行ボタンを押さずに常に実行
Excel(エクセル)
-
18
【VBA】Worksheet_changeイベントで特定のキーが押されたときだけ無効にしたい
Visual Basic(VBA)
-
19
Excel VBAでのWorksheet_Changeが動作しない原因
Excel(エクセル)
-
20
数式による空白を無視して最終行を取得するマクロ
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一番好きなみそ汁の具材は?
- ・泣きながら食べたご飯の思い出
- ・「これはヤバかったな」という遅刻エピソード
- ・初めて自分の家と他人の家が違う、と意識した時
- ・いちばん失敗した人決定戦
- ・思い出すきっかけは 音楽?におい?景色?
- ・あなたなりのストレス発散方法を教えてください!
- ・もし10億円当たったら何に使いますか?
- ・何回やってもうまくいかないことは?
- ・今年はじめたいことは?
- ・あなたの人生で一番ピンチに陥った瞬間は?
- ・初めて見た映画を教えてください!
- ・今の日本に期待することはなんですか?
- ・集中するためにやっていること
- ・テレビやラジオに出たことがある人、いますか?
- ・【お題】斜め上を行くスキー場にありがちなこと
- ・人生でいちばんスベッた瞬間
- ・コーピングについて教えてください
- ・あなたの「プチ贅沢」はなんですか?
- ・コンビニでおにぎりを買うときのスタメンはどの具?
- ・おすすめの美術館・博物館、教えてください!
- ・【お題】大変な警告
- ・洋服何着持ってますか?
- ・みんなの【マイ・ベスト積読2024】を教えてください。
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・最強の防寒、あったか術を教えてください!
- ・歳とったな〜〜と思ったことは?
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルである行以下全部を削...
-
Wordでドロップダウンリスト連動
-
「無」と「未」の使い方
-
VBAでファイルを開くときにファ...
-
Jw-cadの範囲指定で文字が選択...
-
ipadのpagesでMS明朝を使う方法...
-
Excel VBA あるセルでENTERを押...
-
「これが」「これで」いいです...
-
大至急!
-
EXCEL VBAで全選択範囲の解除
-
Excel 行列が選択出来ない
-
EXCELピボットテーブル(複数ア...
-
エクセルの重なってしまったエ...
-
シフトキーを使った範囲選択が...
-
Word差し込み印刷 初期ディレク...
-
Simejiで作ったきせかえを消す...
-
Google Earth Pro(グーグルア...
-
Excel VBAでn行毎に行の選択
-
Androidのスマホで毎回毎回ホー...
-
マクロでリンクを更新しないで開く
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルである行以下全部を削...
-
EXCEL VBAで全選択範囲の解除
-
「無」と「未」の使い方
-
VBAでファイルを開くときにファ...
-
ipadのpagesでMS明朝を使う方法...
-
Excel VBA あるセルでENTERを押...
-
Jw-cadの範囲指定で文字が選択...
-
Wordでドロップダウンリスト連動
-
大至急!
-
Androidのスマホで毎回毎回ホー...
-
「これが」「これで」いいです...
-
Excel 行列が選択出来ない
-
Google Earth Pro(グーグルア...
-
エクセルの重なってしまったエ...
-
シフトキーを使った範囲選択が...
-
Simejiで作ったきせかえを消す...
-
Excel VBAでn行毎に行の選択
-
選択と採択の違い
-
EXCELピボットテーブル(複数ア...
-
WORDでテキストを全て選択し一...
おすすめ情報