
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で質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教えるわが家の防犯対策術!
ホームセキュリティのプロが、家庭の防犯対策を真剣に考える 2組のご夫婦へ実際の防犯対策術をご紹介!どうすれば家と家族を守れるのかを教えます!
-
Enterキーでマクロを起動さす。
その他(ソフトウェア)
-
エクセルでエンターを押すと任意のセルに移動は出来ますか?
その他(コンピューター・テクノロジー)
-
VBA エンターキーでイベントに入りたい。
PowerPoint(パワーポイント)
-
4
Enterキーで順番にセルの移動する。
Visual Basic(VBA)
-
5
値を入力後、自動的にアクティブセルが移動するマクロ
Excel(エクセル)
-
6
EXCEL あるセルに数字が入力されれば既存マクロ実行させたい
Excel(エクセル)
-
7
テキストボックス(VBA)でEnterを押したときに作動するマクロ
Access(アクセス)
-
8
EXCELでENTERキーでセルの移動マクロ
Excel(エクセル)
-
9
エクセル2010セル入力後指定の離れた場所に移動?
Excel(エクセル)
-
10
Excel vbaでキーの操作の入力
Excel(エクセル)
-
11
エクセルのVBA 特定のセルでエンターキーでマクロ実行
Excel(エクセル)
-
12
エクセルVBA 文字を入力したら右へ移動 文字を入力せずにエンターを押しても右へ移動させたい
Excel(エクセル)
-
13
【Excel VBA】セルの値が変更されたらマクロを実行
その他(Microsoft Office)
-
14
Excel2010でエンターキーにマクロ割り当て
その他(プログラミング・Web制作)
-
15
エクセルVBAを使いセルを指定した順番に異動させ
Excel(エクセル)
-
16
Excel VBAでのWorksheet_Changeが動作しない原因
Excel(エクセル)
-
17
メッセージボックスに表示する文字を大きくしたい
Excel(エクセル)
-
18
セルの自動移動
Excel(エクセル)
-
19
Excel 2010 Enterキーを押すと特定のセルに移動する
Excel(エクセル)
-
20
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
関連するQ&A
- 1 Excel 2010 Enterキーを押すと特定のセルに移動する
- 2 excelで特定のセルからいくつか下にあるセルを特定したい
- 3 VBAで、同一フォルダ内にある複数のExcelブックから、検索、特定のセルの文字列を別ファイルの特定
- 4 エクセルのEnterを押した後のセルの移動の設定で
- 5 エクセル:セル上でEnterを押した時のカーソルの移動方向
- 6 エクセル2002でEnterキーを押した時のセル移動方向について
- 7 詳細設定¥Enterキーを押した後にセルを移動する
- 8 入力後enterを押すと、非保護の別セルへ移動したい。(エクセル)
- 9 vba:特定のセルに入力したと同時に隣のセルの値を特定のセルの下の行に自動入力したい
- 10 vba:特定のセルに入力したと同時に隣のセルの値を特定のセルの下の行に自動入力したい_No.2
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
人気Q&Aランキング
-
4
Jw-cadの範囲指定で文字が選択...
-
5
Excel2003にて(ツール→オプシ...
-
6
Simejiで作ったきせかえを消す...
-
7
Excel VBA あるセルでENTERを押...
-
8
選択番号を書き忘れたときの点...
-
9
「これが」「これで」いいです...
-
10
シフトキーを使った範囲選択が...
-
11
大至急!
-
12
「無」と「未」の使い方
-
13
選択と採択の違い
-
14
Wordのオートシェイプの吹...
-
15
Excel 行列が選択出来ない
-
16
Wordの表の行選択ができない
-
17
エクセル 数式だけ残し数値の...
-
18
Wordで作った地図をそのまま縮...
-
19
ファイヤーワークスでの画像の...
-
20
OutlookExpressメール本文が選...
おすすめ情報