
No.3
- 回答日時:
こんにちは
補足を見ると、イベント処理のコードのようですが、同じイベントに対する処理を複数記述すると、実行時に「同じ名前のプロシージャがある」としてエラーになります。
実行のタイミングは同じなのでしょうから、一つにまとめて記述してください。
まとめるのが嫌なら、それぞれを普通の異なる名称にしておいて、イベント処理のコードからそれぞれを呼び出すようにしてください。
※ 異なるイベントに対する処理であれば、当然ながら、複数記述することは可能です。
No.2
- 回答日時:
あるブックの特定のシートでいくつかの異なる作業をさせるコード(VBA)を設定することは可能です。
シートに設定されるイベント(シートを開く、セルを選ぶ、値を変更するなどなど)ごとの動作を書くことができますし、そのシートを含めたブック全体で動作するコードを書くことも可能です。特定のシートのイベントに複数の動作を設定するときはイベントの内容を条件分岐させることで条件に合った動作コードを書くことが出来ます。例えば値を変更したとき何かをさせる場合は変更されたセルにより動作を分ければそれぞれの決められた動作を行うことが出来ます。
No.1
- 回答日時:
Private Subは機能毎に用意されてるので、複数機能を実装したい処理ではPrivate Subを複数書きます。
下図の様に、複数が並びます。
Private Sub Worksheet_Change(ByVal Target As Range)
~
End Sub
Private Sub Worksheet_FollowHyperlink(ByVal Target As Hyperlink)
~
End Sub
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
~
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 2 2022/06/22 11:19
- Excel(エクセル) エクセルVBAで複数のシート印刷設定 1 2022/09/07 12:03
- Excel(エクセル) エクセル バーコード作成で他のシートを参照するには? 2 2023/05/03 16:57
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 1 2023/04/21 13:46
- Visual Basic(VBA) Excel VBA マクロ 先頭行の固定とオートフィルター設定を全てのシートに適用したいです 1 2022/11/12 15:32
- Excel(エクセル) VBA セルの値と同じ名前のシートにデータを貼り付けするやり方を教えてください 2 2022/05/17 16:26
- Visual Basic(VBA) エクセルのマクロについて教えてください。 1 2023/08/03 11:27
- Excel(エクセル) VBAで、シート間の転記するコードを教えてください。 4 2023/03/26 10:43
- Excel(エクセル) ExcelのVBAコードについて教えてください。 1 2022/06/17 15:40
- Visual Basic(VBA) エクセルのマクロについて教えてください。 5 2023/07/14 12:49
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルVBAでオブジェクトが必...
-
エクセルのVBAについて教えてく...
-
エクセルVBAで自動チャート作成...
-
エクセルを共有にすると、シー...
-
マクロ実行後、画面がちかちか...
-
Access-VBAでExcelファイ...
-
エクセルで品番を入れると、そ...
-
Excelで、あるセルの値に応じて...
-
エクセルで離れた列を選択して...
-
B列の最終行までA列をオート...
-
Excelのシート上のShapeにイベ...
-
「段」と「行」の違いがよくわ...
-
EXCELのSheet番号って変更でき...
-
特定の文字がある行以外を削除...
-
別ブックをダイアログボックス...
-
エクセルのセルに指定画像(.jpg...
-
エクセル 上下で列幅を変えるには
-
VBAマクロ実行時エラーの修正に...
-
VBA シートをコピーする際に Co...
-
エクセルVBAが途中で止まります
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルVBAでオブジェクトが必...
-
エクセルのVBAについて教えてく...
-
複数シートを一括で保護を掛け...
-
Access-VBAでExcelファイ...
-
エクセルマクロ(超初心者)
-
マクロのコマンドボタン《Activ...
-
エクセルを共有にすると、シー...
-
コンボボックスへ降順に表示す...
-
エクセルで品番を入れると、そ...
-
VBAでVlookup機能を使うときに...
-
マクロ実行後、画面がちかちか...
-
Excell VBA にて配列に定数を代...
-
マクロのイベントトリガー
-
Excelに関数使用を調べる方法
-
別のブックを開く時にシートを...
-
エクセルのマクロ(大量データ...
-
EXCELに関する質問
-
Auto_Openマクロ
-
エクセルマクロ 変数をワーク...
-
「段」と「行」の違いがよくわ...
おすすめ情報
回答ありがとうございます。
一つ目のコードが
Private Sub Worksheet_Calculate()
Dim cell As Range
Dim result As Integer
For Each cell In Range("F2:F12")
If cell.Value = "確認必要" Then
result = MsgBox("べんり帳が更新されております。" & vbCrLf & "差分を行いブック内の便利帳の修正をお願いします。", vbYesNo + vbExclamation)
If result = vbYes Then
Call 便利帳差分
Else
End If
Exit Sub
End If
Next cell
End Sub
で
2つ目のコードが
Private Sub Worksheet_Calculate()
Dim cell As Range
Dim result As Integer
For Each cell In Range("K2:K12")
If cell.Value = "確認必要" Then
result = MsgBox("条例が更新されております。" & vbCrLf & "対象条例の「確認必要」をクリックし"& vbCrLf & "各条例を確認し、"& vbCrLf & "ブック内の条例を修正してください。", vbOKOnly + vbExclamation)
Exit Sub
End If
Next cell
End Sub
回答ありがとうございます。
私の補足を確認して頂き、解決方法を教えて頂けますでしょうか。
よろしくお願いします。