
前回どなたかが質問されて回答を見せてもらったら私のやりたいことと同じだったので実行してみましたが出来なかったのでもう一度質問をさせてください。
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.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
No.2
- 回答日時:
値を変化したことによる処理の起動は、(上記プログラムでは)A1セルだけに限定されてますが、判っていますか。
そしてA1で1と入力されたときだけメッセージボックスが出るようになってますが、判ってますか。
この回答への補足
すいません判っていませんでした。
そうするとMsgBox出て終わりなのでしょうか。
A1で1と入力されたときだけメッセージボックスが出るようになってますは判っていますが、では、セルの値が1になったときにA1以外のセルのコピーとかセルからセルへの値の入れ替えなど沢山の処理がマクロに付け加えたりするにはどうすれば出来るのですか、別に書いたマクロを実行したいのですが、現在はAUTO_OPNEで使ってやっているのですがそれだとファイルを再度開かないと実行しないので終了するまでにデータが変わってしまって、出来ればリアルタイムに実行をしたいのですが、お手数をかけますが、よろしくお願いします。
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
プログラムはこのように書けばいいのですか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
EXCEL あるセルに数字が入力されれば既存マクロ実行させたい
Excel(エクセル)
-
セルに入力するたびにマクロを実行する
Visual Basic(VBA)
-
エクセルのマクロをセルの値に応じて自動起動したい
Visual Basic(VBA)
-
-
4
あるセルに特定の文字列を打つと、他のセルに決められた文字が自動入力するように
Excel(エクセル)
-
5
VBA 何かしら文字が入っていたら
Visual Basic(VBA)
-
6
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
7
エクセル イベントマクロ Changeイベントを複数作りたい
Access(アクセス)
-
8
セルの結果でマクロ実行
Visual Basic(VBA)
-
9
VBAのコマンドボタンの文字列の改行方法は?
Visual Basic(VBA)
-
10
【VBA】Worksheet_changeイベントで特定のキーが押されたときだけ無効にしたい
Visual Basic(VBA)
-
11
EXCEL VBA セルに既に入力されている文字に文字を追加する
Excel(エクセル)
-
12
VBAでセルに値が入ったときにイベントを起こしたい
Visual Basic(VBA)
-
13
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
14
エクセルで指定のセルのみ完全非表示にしたい。
Excel(エクセル)
-
15
VBAで特定の文字が入力されたセルを選択
Excel(エクセル)
-
16
Excel VBAでのWorksheet_Changeが動作しない原因
Excel(エクセル)
-
17
【Excel VBA】セルの値が変更されたらマクロを実行
その他(Microsoft Office)
-
18
VBA Cのセルが空白でなかったら、Aのセルに順番に数値を入力
Visual Basic(VBA)
-
19
【EXCEL】【VBA】空欄は飛ばして処理する方法を教えて下さい。
Excel(エクセル)
-
20
【VBA】特定列に文字が入っていたらそのセル行をコピーしてマスターブックの同じ行に貼り付けたい
その他(Microsoft Office)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
if関数の複数条件について
-
excel
-
エクセルシートの見出しの文字...
-
VLOOKUP FALSEのこと
-
エクセルでフィルターした値を...
-
エクセルの文字数列関数と競馬...
-
【マクロ】数式を入力したい。...
-
【画像あり】オートフィルター...
-
エクセルに写真が貼れない(フ...
-
【マクロ】【画像あり】関数が...
-
【画像あり】【関数】指定した...
-
Dir関数のDo Whileステートメン...
-
【マクロ】アクティブセルの時...
-
セルにぴったし写真を挿入
-
【マクロ】エラー【#DIV/0!】が...
-
勤怠表について ABS、TEXT関数...
-
【マクロ】実行時エラー '424':...
-
表計算ソフトでの様式の呼称
-
【関数】3つのセルの中で最新...
-
【マクロ】excelファイルを開く...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【マクロ】実行時エラー '424':...
-
エクセルのVBAで集計をしたい
-
Office2021のエクセルで米国株...
-
【画像あり】オートフィルター...
-
vba テキストボックスとリフト...
-
他のシートの検索
-
【マクロ】【相談】Excelブック...
-
【マクロ】【配列】3つのシー...
-
【マクロ】元データと同じお客...
-
【マクロ】数式を入力したい。...
-
【マクロ】左のブックと右のブ...
-
エクセルの関数について
-
エクセルのリストについて
-
【マクロ】変数に入れるコード...
-
エクセルシートの見出しの文字...
-
【マクロ】excelファイルを開く...
-
【関数】3つのセルの中で最新...
-
エクセルの複雑なシフト表から...
-
【マクロ】【画像あり】❶ブック...
-
LibreOffice Clalc(またはエク...
おすすめ情報