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も見ています
-
餃子を食べるとき、何をつけますか?
みんな大好き餃子。 ふと素朴な疑問ですが、餃子には何をつけて食べますか? 王道は醤油とお酢でしょうか。
-
これ何て呼びますか
あなたのお住いの地域で、これ、何て呼びますか?
-
初めて自分の家と他人の家が違う、と意識した時
子供の頃、友達の家に行くと「なんか自分の家と匂いが違うな?」って思いませんでしたか?
-
【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
【お題】 ・買ったばかりの自転車を分解してひと言
-
ハマっている「お菓子」を教えて!
この世には、おいしいお菓子がありすぎて……。 次何を食べたらいいか迷っています。 みなさんが今、ハマっている「お菓子」を教えてください!
-
値を入力後、自動的にアクティブセルが移動するマクロ
Excel(エクセル)
-
Enterキーでマクロを起動さす。
その他(ソフトウェア)
-
エクセルのVBA 特定のセルでエンターキーでマクロ実行
Excel(エクセル)
-
-
4
エクセルでエンターを押すと任意のセルに移動は出来ますか?
その他(コンピューター・テクノロジー)
-
5
エクセルでエンターを押すと隣のセルではなく指定したセルに!
Excel(エクセル)
-
6
Enterキーで順番にセルの移動する。
Visual Basic(VBA)
-
7
VBA エンターキーでイベントに入りたい。
PowerPoint(パワーポイント)
-
8
テキストボックス(VBA)でEnterを押したときに作動するマクロ
Access(アクセス)
-
9
EXCELでENTERキーでセルの移動マクロ
Excel(エクセル)
-
10
エクセルVBAを使いセルを指定した順番に異動させ
Excel(エクセル)
-
11
excelで セルの移動時にマクロ実行を設定したい。
Excel(エクセル)
-
12
エクセルVBAで、条件に一致するセルへ移動
Excel(エクセル)
-
13
エクセル イベントマクロ Changeイベントを複数作りたい
Access(アクセス)
-
14
特定のセルがアクティブになったときのイベント?
Excel(エクセル)
-
15
エクセルのラベルの値(文字列)を垂直方向で中央揃えにするには?
Excel(エクセル)
-
16
Excelで教えてください。 バーコードリーダーで読み込みしたあと セルを自動で次のセルに行くように
Excel(エクセル)
-
17
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
18
Excel VBAでのWorksheet_Changeが動作しない原因
Excel(エクセル)
-
19
メッセージボックスに表示する文字を大きくしたい
Excel(エクセル)
-
20
入力するセルの順番を自動選択(セルの移行)
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルである行以下全部を削...
-
「無」と「未」の使い方
-
Excel VBA あるセルでENTERを押...
-
EXCEL VBAで全選択範囲の解除
-
ipadのpagesでMS明朝を使う方法...
-
VBAでファイルを開くときにファ...
-
大至急!
-
Google Earth Pro(グーグルア...
-
Wordでドロップダウンリスト連動
-
Excel 行列が選択出来ない
-
「これが」「これで」いいです...
-
エクセルの重なってしまったエ...
-
【android】アクセスポイントの...
-
Androidのスマホで毎回毎回ホー...
-
Word差し込み印刷 初期ディレク...
-
Simejiで作ったきせかえを消す...
-
選択番号を書き忘れたときの点...
-
Excel VBAでn行毎に行の選択
-
Jw-cadの範囲指定で文字が選択...
-
選択と採択の違い
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルである行以下全部を削...
-
「無」と「未」の使い方
-
EXCEL VBAで全選択範囲の解除
-
VBAでファイルを開くときにファ...
-
ipadのpagesでMS明朝を使う方法...
-
Excel VBA あるセルでENTERを押...
-
Excel 行列が選択出来ない
-
Wordでドロップダウンリスト連動
-
Jw-cadの範囲指定で文字が選択...
-
Androidのスマホで毎回毎回ホー...
-
「これが」「これで」いいです...
-
大至急!
-
Google Earth Pro(グーグルア...
-
EXCELピボットテーブル(複数ア...
-
選択と採択の違い
-
Simejiで作ったきせかえを消す...
-
Excel VBAでn行毎に行の選択
-
シフトキーを使った範囲選択が...
-
選択番号を書き忘れたときの点...
-
リストボックスのプロパティ「...
おすすめ情報