いつもお世話になっております
B列に日付があり
今日の日付が過ぎたらその行を削除したい
下記のコードは作成したものの
何回も実行しないときえないです。
全部きえません。
わかる方おしえてくれませんでしょうか
B列の日付が 例)23年03月15日となっているため
DateSerial(Year(.Cells(i, "B")), Month(.Cells(i, "B")), Day(.Cells(i, "Q")))
しています。
間違えかもしれません。
Sub sdelete()
Dim wS As Worksheet
Dim i As Long
For Each wS In Worksheets
With wS
For i = 5 To .Cells(.Rows.Count, "B").End(xlUp).Row
If .Cells(i, "B").Value <> "" Then
If IsDate(.Cells(i, "B").Value) = True Then
If Date > DateSerial(Year(.Cells(i, "B")), Month(.Cells(i, "B")), Day(.Cells(i, "Q"))) Then
.Range(.Cells(i, "B"), .Cells(i, "H")).Delete
End If
End If
End If
Next
End With
Next
End Sub
A 回答 (1件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:
そりゃソーでしょ。
だってね、行を削除したら、その下の全部の行が上へ移動する訳でしょ?
削除した行へ上移動した行は、もう処理対象外になりますからね。
例えば、i=10がヒットして10行目を削除したら、削除前の11行目が10行目に移動するわけ。
で、その次はiがカウントアップしてi=11になる。
10行目に移動した行はもう処理されないでしょ?
削除したら、iを1個戻す。i=i-1にして置いて、再度、前のi値で実行する。
ありがとうございます
わかりました。
For i = .Cells(.Rows.Count, "B").End(xlUp).Row To 3 Step -1
ですね
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBAコードが作動せず、どこに問題があるのか教えて下さい。 3 2023/06/13 13:20
- Visual Basic(VBA) VBA Userformで一部別シートに転記がしたいのですが 2 2023/05/24 13:08
- Excel(エクセル) マクロで最終行から上に検索を逆にしたい 1 2022/05/17 18:27
- Visual Basic(VBA) エラーコード1004 6 2022/06/09 14:12
- Excel(エクセル) VBAの指示の内容 昨日こちらでご教示頂いたのですが初心者な為、一つ一つの指示が何をやっているのかわ 2 2022/10/25 18:08
- Excel(エクセル) なぜExit Subがあるのかわかりません 4 2023/02/19 12:34
- Visual Basic(VBA) いつもお世話になっております、VBAで教えて頂きたいのですが 2 2022/05/05 22:20
- Visual Basic(VBA) 【VBA】特定のワードが入っている行全体を塗りつぶしたい 4 2022/04/20 15:22
- Visual Basic(VBA) VBA 別ブックからの転記の高速化について VBA 別ブックからの転記の高速化についてご教授下さい。 19 2022/07/26 13:07
- Excel(エクセル) VBAについて 3 2022/06/19 18:19
このQ&Aを見た人はこんなQ&Aも見ています
-
性格の違いは生まれた順番で決まる?長男長女・中間子・末っ子・一人っ子の性格の傾向
同じ環境で生まれ育っても、生まれ順で性格は違うものなのだろうか。家庭教育研究家の田宮由美さんに教えてもらった。
-
基準日以前のデータを範囲を指定して削除するVBA
Excel(エクセル)
-
エクセルで。
Excel(エクセル)
-
エクセルVBA 今日の日付行を削除
Excel(エクセル)
-
-
4
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
5
VBA 指定した列にある日時データから時間を削除する方法について
Excel(エクセル)
-
6
エクセルで昨日までの日付データ行を非表示するVBAについて!
Excel(エクセル)
-
7
エクセル マクロ 特定の日付"以降を削除"
セキュリティソフト
-
8
難問 VBA 今日の日付より前に対するイベント処理
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBA:Openステートメントで開い...
-
教えて!gooにはどのカテゴリが...
-
職場の人と仕事中に喧嘩して LI...
-
日テレニュースHP、記事削除は...
-
同じ質問
-
指定した文字があった場合、そ...
-
エクセルVBAで行削除時にエラー...
-
バッチファイルを使用したsql@p...
-
喧嘩をしてLINE削除され、 また...
-
アクセスにおいて間違って削除...
-
エクセルで下の空白行を削除したい
-
インスタグラムのギャラリーの...
-
エクセルで住所の混在する「丁...
-
Facebookメッセンジャーの不具合
-
(Access)複数条件の重複デー...
-
もう関わりたくない人がいたらL...
-
Facebookに自分が四つもアップ...
-
Excel 数式を入れているため、...
-
メーリングリストから特定の人...
-
動的に作成したコントロールの...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
もはや喧嘩売ってるのか私(笑...
-
回答がついてる普通の質問まで...
-
指定した文字があった場合、そ...
-
VBA:Openステートメントで開い...
-
AI削除には数多のキーワード設...
-
インスタグラムのギャラリーの...
-
バッチファイルを使用したsql@p...
-
Yahooフリマってどれくらい時間...
-
Facebookメッセンジャーの不具合
-
削除の対象について
-
エクセルで住所の混在する「丁...
-
ビジネスパートナーから送られ...
-
女友達にLINEしたら、既読スル...
-
もう関わりたくない人がいたらL...
-
喧嘩をしてLINE削除され、 また...
-
猫にグラグラの熱湯かける動画...
-
すべてやりきった、大満足を意...
-
インスタアカウント、前の携帯...
-
Facebookに自分が四つもアップ...
-
Facebookで間違ってスートリー...
おすすめ情報