Excel VBA質問箱 IV

当質問箱は、有志のボランティア精神のおかげで成り立っています。
問題が解決したら、必ずお礼をしましょうね。
本サイトの基本方針をまとめました。こちら をご一読ください。

投稿種別の選択が必要です。ご注意ください。
迷惑投稿防止のため、URLの入力を制限しています。ご了承ください。


18027 / 76738 ←次へ | 前へ→

【64155】Re:教えて下さい。
発言  n  - 10/1/22(金) 11:30 -

引用なし
パスワード
   ▼たつや さん:

複数セル範囲の変化時、Worksheet_Changeには複数セル範囲が渡されます。

Sub test()
  Range("A1:A2").Value = 1
End Sub

Private Sub Worksheet_Change(ByVal Target As Range)
  Debug.Print Target.Address
End Sub

この場合のTargetは複数セル範囲。
>If Target.Value <> "" Then
これは
If Range("A1:A2").Value <> "" Then
などと書いている事と同じになります。
あるいは
Dim v As Variant
v = Range("A1:A2").Value
If v <> "" Then

Range("A1:A2").Valueは配列です。
If 配列 <> "" Then
という配列に対する <>"" 評価はできないですね?

Dim r As Range
For Each r In Target

といった感じでTargetの個々に対して処理する必要があります。

Application.EnableEvents = False/True
の制御も入れておいたほうが良いでしょう。
0 hits

【64139】教えて下さい。 らいち 10/1/21(木) 19:49 質問
【64143】Re:教えて下さい。 kanabun 10/1/21(木) 21:49 発言
【64144】Re:教えて下さい。 UO3 10/1/21(木) 21:50 回答
【64145】Re:教えて下さい。 UO3 10/1/21(木) 21:55 発言
【64146】Re:教えて下さい。 たつや 10/1/21(木) 21:59 回答
【64147】Re:教えて下さい。 UO3 10/1/21(木) 22:28 発言
【64148】Re:教えて下さい。 たつや 10/1/22(金) 7:19 回答
【64149】Re:教えて下さい。 らいち 10/1/22(金) 8:58 お礼
【64155】Re:教えて下さい。 n 10/1/22(金) 11:30 発言
【64169】Re:教えて下さい。 らいち 10/1/22(金) 18:14 質問
【64170】Re:教えて下さい。 n 10/1/22(金) 22:16 発言
【64171】Re:教えて下さい。 たつや 10/1/23(土) 0:43 発言
【64173】Re:教えて下さい。 たつや 10/1/23(土) 1:06 発言
【64174】Re:教えて下さい。 n 10/1/23(土) 1:20 発言
【64175】Re:教えて下さい。 たつや 10/1/23(土) 1:46 発言
【64176】Re:教えて下さい。 たつや 10/1/23(土) 1:58 発言
【64214】Re:教えて下さい。 らいち 10/1/26(火) 15:46 発言
【64223】Re:教えて下さい。 n 10/1/26(火) 20:08 発言
【64225】Re:教えて下さい。 らいち 10/1/27(水) 9:29 お礼

18027 / 76738 ←次へ | 前へ→
ページ:  ┃  記事番号:
2610219
(SS)C-BOARD v3.8 is Free