前回どなたかが質問されて回答を見せてもらったら私のやりたいことと同じだったので実行してみましたが出来なかったのでもう一度質問をさせてください。
1.実行したのですが、なにも実行されません。
2.実行したらメッセジBOXだけは実行するのですが、後のコマンドが実行されずにエラーになります。
もう一度詳しく教えてください。
マクロ初心者ですよろしくお願いします。
1.【シートモジュールで条件判定し、マクロを起動する】
通常はこちらの方法が使われます。
Private Sub Worksheet_Change(ByVal Target As Range)
'変化のあったセルがA1セルか?
If Target.Address = "$A$1" Then
'条件判定:A1セルの値は 1 か?
If Target.Value = 1 Then
MsgBox "A1セルは条件を満たしました"
End If
End If
End Sub
2.【ワークシート上で条件判定し、マクロを起動する】
処理内容にもよっては不向きな場合もありますが、こんな方法も
あります。
マクロを Sub ではなく、Function 、、つまり関数にしてしまいます。
Function TestMacro() '<-- Sub を Function に替える
MsgBox "A1セルは条件を満たしました"
TestMacro = "" '戻り値はなし
End Function
そして、ワークシートの B1 セルに次の式を入力します。()は必須
です。
=IF(A1=1,TestMacro(),"")
No.1
- 回答日時:
1.実行したいシートのシート名を右クリックしてコードの表示を選びます。
出てきたVBEに記述してください。2.後のコマンドとは何でしょう?エラーはどのようなものが出ますか?
この回答への補足
ありがとうございました。
下のもので実行すると、MsgBoxまでは、OKですが次の段階でとまってしまいます。
何かが違いますか、?今仮にSheet2をSheet1にコピーをするものをつけてみて実行しました。
Private Sub Worksheet_Change(ByVal Target As Range)
'変化のあったセルがA1セルか?
If Target.Address = "$A$1" Then
'条件判定:A1セルの値は 1 か?
If Target.Value = 1 Then
MsgBox "A1セルは条件を満たしました"
Range("a2") = "1123"
Sheets("Sheet2").Select
Range("A1:C24").Select’←ここでエラー【黄色くなって止まる
Selection.Copy
Sheets("Sheet1").Select
Range("B8:D31").Select
ActiveSheet.Paste
End If
End If
End Sub
プログラムはこのように書けばいいのですか?
No.2
- 回答日時:
値を変化したことによる処理の起動は、(上記プログラムでは)A1セルだけに限定されてますが、判っていますか。
そしてA1で1と入力されたときだけメッセージボックスが出るようになってますが、判ってますか。
この回答への補足
すいません判っていませんでした。
そうするとMsgBox出て終わりなのでしょうか。
A1で1と入力されたときだけメッセージボックスが出るようになってますは判っていますが、では、セルの値が1になったときにA1以外のセルのコピーとかセルからセルへの値の入れ替えなど沢山の処理がマクロに付け加えたりするにはどうすれば出来るのですか、別に書いたマクロを実行したいのですが、現在はAUTO_OPNEで使ってやっているのですがそれだとファイルを再度開かないと実行しないので終了するまでにデータが変わってしまって、出来ればリアルタイムに実行をしたいのですが、お手数をかけますが、よろしくお願いします。
No.3ベストアンサー
- 回答日時:
全てのセルで1が入力されたら実行するには、
> '変化のあったセルがA1セルか?
> If Target.Address = "$A$1" Then
この部分を改造します。具体的に言うとコメントアウトしてください。もしくは削除する。これに対応するEnd Ifも忘れずに。
親切にコメントで動作を書いてあるのに無駄なようですね残念です。
この回答への補足
うまく説明が出来なくてごめんなさい。
この動作はうまくいきました。A1に1を入力するとうまくいきます。
ありがとうございました。
ただ、手入力でA1に1を入力をして(セルの変化がある)ではよいのですが、プロシージャーでデータが書き換わったときに動作させたいのですが、どうすればいいのでしょうか
何度もすいませんがよければ教えてください。
No.4
- 回答日時:
No.1の補足に対する、回答として
Private Sub Worksheet_Change(ByVal Target As Range)
'変化のあったセルがA1セルか?
If Target.Address = "$A$1" Then
'条件判定:A1セルの値は 1 か?
If Target.Value = 1 Then
MsgBox "A1セルは条件を満たしました"
Range("a2") = "1123"
Sheets("Sheet2").Select
'/// Range("A1:C24").Select '←ここでエラー【黄色くなって止まる
Sheets("Sheet2").Range("A1:C24").Select ' Sheets("Sheet2"). を付け加えました
Selection.Copy
Sheets("Sheet1").Select
'/// Range("B8:D31").Select ' Range("B8:D31"). でも間違えでは無いが、
Range("B8").Select ' 左上のセルを指定
ActiveSheet.Paste
End If
End If
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) excel2021で実行できないマクロ。どこを直したらいいのか 2 2022/03/28 03:40
- Excel(エクセル) エクセルの自動更新のタイミングについて 1 2022/07/20 16:12
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 2 2023/05/23 16:28
- Visual Basic(VBA) まとめシートから集計シートへA列のコードが一致したら1行コピーするマクロをネット上で見つけました。こ 1 2022/08/30 14:11
- Visual Basic(VBA) エクセルのマクロについて教えてください。 1 2022/10/13 08:41
- Visual Basic(VBA) 別シートから年齢別の件数をカウントしたいの続き 5 2023/01/24 00:16
- Excel(エクセル) エクセルVBAでオブジェクトが必要です 2 2022/09/10 16:37
- Visual Basic(VBA) 【VBA】Excelで罫線を引きたい 3 2022/07/14 12:04
- Excel(エクセル) エクセルのイベントプロシージャーでF列の最終行のセルの入力をトリガーにしたいのですが 1 2022/10/14 09:36
- Visual Basic(VBA) 【追加】ファイルを閉じてダイアログで保存した時だけ処理の実行をする 3 2022/03/23 15:43
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教える店舗&オフィスのセキュリティ対策術
中・小規模の店舗やオフィスのセキュリティセキュリティ対策について、プロにどう対策すべきか 何を注意すべきかを教えていただきました!
-
EXCEL あるセルに数字が入力されれば既存マクロ実行させたい
Excel(エクセル)
-
エクセルのマクロをセルの値に応じて自動起動したい
Visual Basic(VBA)
-
【vba】指定範囲の中に任意の文字があるときの条件分岐
Excel(エクセル)
-
-
4
エクセルvba (ByVal Target As Range)について
Excel(エクセル)
-
5
セルの値が変ると自動でマクロが実行される。
その他(Microsoft Office)
-
6
ある列のセルに特定の文字が入っていたら他のセルに決まった文字を入れる
Word(ワード)
-
7
エクセル マクロの実行について
Excel(エクセル)
-
8
エクセル イベントマクロ Changeイベントを複数作りたい
Access(アクセス)
-
9
値を入力後、自動的にアクティブセルが移動するマクロ
Excel(エクセル)
-
10
Excel vbaで特定の文字以外が入っている時、メッセージを表示させるプログラムについて
Visual Basic(VBA)
-
11
Enterキーでマクロを起動さす。
その他(ソフトウェア)
-
12
EXCELで特定の文字列を入力→エラー表示したい
その他(Microsoft Office)
-
13
Excel VBA あるセルでENTERを押すと特定のセルへ移動したい
Excel(エクセル)
-
14
セルに入力するたびにマクロを実行する
Visual Basic(VBA)
-
15
A1セルに入力したら、入力時間をA2セルに自動挿入
Excel(エクセル)
-
16
End Sub が必要です。
Access(アクセス)
-
17
VBA(エクセル)で自動的にボタンをクリックさせるには
その他(プログラミング・Web制作)
-
18
エクセル ダブルクリック入力の範囲が複数の場合
Excel(エクセル)
-
19
【VBA】特定列に文字が入っていたらそのセル行をコピーしてマスターブックの同じ行に貼り付けたい
その他(Microsoft Office)
-
20
VBA 何かしら文字が入っていたら
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセル初心者です 関数の入れ...
-
【関数】先頭だけにある、半角...
-
エクセル 白黒印刷で白線を印刷...
-
Excelのチェックボックスの使い...
-
【関数】適切な文字数の数字を...
-
Excelのpivotについて質問です
-
Excel ピボットテーブルで日付...
-
LOOKUP関数を使えばいいのでし...
-
エクセル関数を教えてください
-
エクセルのセルに同じ大きさの...
-
UNIQUE関数が使えないバージョ...
-
excelの不要な行の削除ができな...
-
エクセルで「-0.0」と表示さ...
-
時間によってファイル名が変わ...
-
WPS OFFICEでの縦書きについて
-
エクセルの関数について教えて...
-
Aというブックの1というシート...
-
【マクロ】シート名を取得する...
-
VBA Private Sub Worksheet_Cha...
-
VBA、Excelのworkbook.open に...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel 2019 のピボットテーブル...
-
[関数得意な方]教えて下さい・...
-
Excelにてある膨大なデータを管...
-
[関数について]わかる方教えて...
-
Excel初心者です。 詳しい方、...
-
excelの不要な行の削除ができな...
-
エクセル関数に詳しい方教えて...
-
INDIRECTを使わず excelで複数...
-
[オートフィルタ]で抽出された...
-
エクセルの神よ、ご回答を! エ...
-
エクセル関数に詳しい方、教え...
-
各ページの1番上の表示について
-
Excelで写真のような表を作った...
-
エクセルで不等号記号(≠)が上に...
-
数学 Tan(θ)-1/Cos(θ)について...
-
Excel 2019 は、SPILL機能があ...
-
Excelで全角を半角にしたいので...
-
条件付き書式を教えてください
-
Excel フィルターを掛けた状態...
-
[オートフィルタ]の適用範囲の...
おすすめ情報