
お世話になります。
VBA初心者です。勉強中に以下コードを見つけましたが、
なぜIfがネストではなく別々なのかがわかりません。
C1に入っている値がA列にあれば無視、
なければ末尾にC1の値を追記するマクロです
Sub ren1()
Dim i As Long, flag As Boolean
For i 2 To Cells(Rows.Count,1).End(xlUp).Row
If Cells(i,1)=Range("C2") Then
flag = True
Exit For
End If
Next
If flag = false Then
Cells(Rows.Count,1).End(xlUp).Offset(1,0)=Range("C2")
End If
End Sub
→flagの条件は一つ目のif文内にあり閉じられたあとに、flagが偽の場合、と出てくるのはおかしくないでしょうか?
なぜこれがちゃんと動くのでしょうか?
No.1ベストアンサー
- 回答日時:
インデント、段下げして、空行作って行番号付けると、
01:Sub ren1()
02: Dim i As Long, flag As Boolean
03:
04: For i 2 To Cells(Rows.Count,1).End(xlUp).Row
05: If Cells(i,1)=Range("C2") Then
06: flag = True
07: Exit For
08: End If
09: Next
10:
11: If flag = false Then
12: Cells(Rows.Count,1).End(xlUp).Offset(1,0)=Range("C2")
13: End If
14:End Sub
02行で宣言した際に、flagは規定値のfalseになる。
04~09まで何回かループした際に、05の条件を満たすと、06でflagはtrueになる。
1回も05の条件を満たさなければ、falseのまま。
Microsoft Docs - ブール型 (Boolean) (Visual Basic)
https://docs.microsoft.com/ja-jp/dotnet/visual-b …
| Boolean の既定値は Falseです。
まぁ、ちゃんと明示的に初期化した方が、質問者さんみたいな誤解招いたり、上みたいなドキュメント調べずに済みます。
No.3
- 回答日時:
こんにちは
前半で「同じ値のセルが存在するか」を調べて、その結果がflagに設定されます。
少し簡略化して書き直してみると・・
flag = False '←明示するために追加
For i = 2 To ~ ' 最終行までループ(ご提示のコードでは「=」が抜けている)
' 同じ値があれば、flag = True にセット
Next
このループを抜けると、
flag = True --- 同じ値のセルが存在する
flag = False --- 同じ値のセルは存在しない
となっているはずなので、その後の処理で、これを利用しているということかと。
※ なお、ご質問には直接関係ありませんが・・・
同じ値が存在するかを調べるだけなら、COUNTIF関数を使って0以上かどうかを見る方法にすると、ループも不要になるので、わかりやすくなるかも知れません。
例えば、調べる対称がA列全体でもかまわなければ、
n = WorksheetFunction.CountIf(Columns(1), Cells(2, 3))
としておけば、n>0 か否かで判断が可能になるので、1行で同じことができるようになります。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) ExcelVBAでDo Until loopのネスト、IF文を使って一致する物と一致しない物としたい 11 2022/12/24 17:46
- Excel(エクセル) VBAの指示の内容 昨日こちらでご教示頂いたのですが初心者な為、一つ一つの指示が何をやっているのかわ 2 2022/10/25 18:08
- Visual Basic(VBA) 数字が「0」の列を削除するため、下記のコードを実行しましたが、コンパイルエラーSubまたはFunct 3 2022/12/04 00:00
- Excel(エクセル) VBAについて 3 2022/06/19 18:19
- Visual Basic(VBA) VBA Userformで一部別シートに転記がしたいのですが 2 2023/05/24 13:08
- Excel(エクセル) マクロで最終行から上に検索を逆にしたい 1 2022/05/17 18:27
- Visual Basic(VBA) VBA処理追加 こちらでご教示頂いたのですが回答完了させてしまいましたのでこちらからまた質問させてく 2 2022/10/27 09:57
- Visual Basic(VBA) Excel VBA キーワードから列を取得して、さらに空欄行を非表示にする 3 2022/10/21 22:49
- Visual Basic(VBA) 別シートから年齢別の件数をカウントしたいの続き 5 2023/01/24 00:16
- Excel(エクセル) エクセルVBAでオブジェクトが必要です 2 2022/09/10 16:37
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
if文を使わずに奇数・偶数を判断
-
ファイルから読み取った「行の...
-
do-while文が禁止される理由
-
入力した数値を倍々するプログラム
-
break文でループを一気に抜ける...
-
階層型ニューラルネットに準ニ...
-
ループを途中で抜けたいのですが。
-
for文while文の無限ループの違...
-
strstr()関数の実装内容について。
-
特定の文字列が出てくるまでの...
-
他言語で言うcontinue文
-
H8/3048マイコンAD/DA変換について
-
「Aに対するBの割合」と「Aに対...
-
複数桁10進数の*桁目だけを抽出...
-
fgetsなどのときのstdinのバッ...
-
#define _CRT_SECURE_NO_WARNIN...
-
信頼区間の1.96や1.65ってどこ...
-
Aの値からBの値を除するとは??
-
「指定されたキャストは有効で...
-
visualstudio C# テキストボッ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
do-while文が禁止される理由
-
ループを途中で抜けたいのですが。
-
Excel VBAで年度をまたぐ期間の...
-
C言語forループが完結した場合...
-
UWSCにてある一定の動作を無限...
-
入力した文字列から母音だけを...
-
excel VBA if文について
-
プログラムで関数は使わない方...
-
C++のvolatileについて
-
入力した数値を倍々するプログラム
-
For文の終了値を関数にしても問...
-
break文でループを一気に抜ける...
-
Delphiで・・・
-
if文の中にfor文なのか、for文...
-
for文while文の無限ループの違...
-
PIC のプログラムについて ど...
-
他言語で言うcontinue文
-
PAD図の書き方
-
C言語、whileループを抜け出す...
-
clock関数を利用した時間計測法...
おすすめ情報