
こんにちは。
特定の文字列が複数あって、その文字列があったときに行ごと削除を行いたいです。
行を削除するマクロは別の方が質問をしていて、コードは分かったのですが、
”特定の文字列”が2つ以上ある場合のコードを教えていただきたいです。
行を削除するマクロは以下の通りです。
----------------------------------------------------
Sub 特定の文字列を含む行を削除()
Dim c As Range
Dim myRow As Long
With Range("A:A")
Set c = .Find("特定の文字列")
Do While Not c Is Nothing
Rows(c.Row).Delete shift:=xlUp
Set c = .Find("特定の文字列")
Loop
End With
End Sub
----------------------------------------------------
Set c = .Find("特定の文字列")の"特定の文字列"を右側へ増やしたりしてみたのですが、
そもそもの考え方が違うのだろうな…と思いました。
詳しい方、何卒よろしくお願い申し上げます。
No.2ベストアンサー
- 回答日時:
こんにちは!
色々やり方はありますが、一例です。
尚、1行目は項目行でデータは2行目以降にあるという前提です。
まずオートフィルタを使うやり方です。
Sub Sample1()
Dim lastRow As Long
Dim myary
myary = Array("赤", "青", "紫")
lastRow = Cells(Rows.Count, "A").End(xlUp).Row
Range("A1").AutoFilter field:=1, Criteria1:=myary, Operator:=xlFilterValues
If Cells(Rows.Count, "A").End(xlUp).Row > 1 Then
Range(Cells(2, "A"), Cells(lastRow, "A")).SpecialCells(xlCellTypeVisible).EntireRow.Select '//★//
End If
ActiveSheet.AutoFilterMode = False
End Sub
次に、コツコツループさせる方法です。
Sub Sample2()
Dim i As Long, k As Long
Dim myRng As Range
Dim myary
myary = Array("赤", "青", "紫")
For i = 2 To Cells(Rows.Count, "A").End(xlUp).Row
For k = 0 To UBound(myary)
If Cells(i, "A") = myary(k) Then
If myRng Is Nothing Then
Set myRng = Cells(i, "A")
Else
Set myRng = Union(myRng, Cells(i, "A"))
End If
Exit For
End If
Next k
Next i
If Not myRng Is Nothing Then
myRng.EntireRow.Select '//★//
End If
End Sub
※ どちらも行選択でやめています。
すぐに削除したい場合は「★」の行の
>Select
を
>Delete
に変更してみてください。m(_ _)m
tom04 様
書いていただいたコードで解決しました!
とても悩んでいたので、すっきりしました。
お知恵を貸していただきありがとうございます。
No.1
- 回答日時:
こんにちは
どのような条件でテストしているのかわかりませんが、ご提示のコードは複数行に存在する場合を想定したコードになっています。
もしかすると、あちこちの列に点在するようなケースでテストしていて、うまくいかないと言っていたりするのでは?
あるいは、完全一致ではなく部分一致も削除したいといったように、どこか前提条件が違っているのかもしれません。
全体の考え方はそのままで使えるはずなので、条件が異なるところを調整すれば良いのではないでしょうか。
https://docs.microsoft.com/ja-jp/office/vba/api/ …
ご回答ありがとうございます。
特定の文字列は複数の列で点在はして居らず、
1列に入力してあります。
上記のコードは1つの特定の文字列(例えば”赤”)を探し、特定の文字列(”赤”)を見つけ出したときに、
”赤”の行自体を削除してくれました。
特定の文字列が複数あってその行を削除したい場合(例えば”赤”と”青”と”紫”)はどうしたらいいのかなと思っていました。
説明が悪く申し訳ございません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
【初月無料キャンペーン実施中】オンライン健康相談gooドクター
24時間365日いつでも医師に健康相談できる!詳しくはコチラ>>
-
指定した文字があった場合、その行を削除するマクロが欲しいです
Excel(エクセル)
-
特定の文字がある行以外を削除するマクロ
その他(Microsoft Office)
-
エクセル 指定した文字列を含む列を削除するには
Excel(エクセル)
-
4
エクセルVBA 特定文字以外の行削除
Excel(エクセル)
-
5
Excel VBA A列が特定の値以外の場合、その行を削除
Excel(エクセル)
-
6
VBAで特定の文字を含まない列の削除方法について
Excel(エクセル)
-
7
【VBA】特定の文字が入っている行の一部を抽出して別シートコピーするには
Visual Basic(VBA)
-
8
【VBA】条件に一致しない行を削除したい 複数条件
Visual Basic(VBA)
-
9
エクセルで特定の行を削除したいのですが。
Excel(エクセル)
-
10
VBAで特定の文字が入力されたセルを選択
Excel(エクセル)
-
11
【Excel VBA】指定行以降をクリアするには?
Visual Basic(VBA)
-
12
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
13
【EXCEL】【VBA】空欄は飛ばして処理する方法を教えて下さい。
Excel(エクセル)
-
14
エクセルで特定の文字が入ってる列を削除方法
Excel(エクセル)
-
15
【VBA】特定列に文字が入っていたらそのセル行をコピーしてマスターブックの同じ行に貼り付けたい
その他(Microsoft Office)
-
16
【VBA】特定の値が入った行をコピーして別シートに貼り付ける方法をおしえていただきたいです。
Excel(エクセル)
-
17
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
18
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
19
【Excel VBA】特定の列以外を削除
Excel(エクセル)
-
20
【VBA】指定した検索条件に一致したら別シートに転記したい
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
人気Q&Aランキング
-
4
EXCELで=より左の文字を一括で...
-
5
MS SQLServer のSQLで文字列の...
-
6
【excel】複数のセルを対象に特...
-
7
エクセルで文字列の最大値を抽...
-
8
Excelで指数表現しないようにす...
-
9
文字列からタブコードを取り除...
-
10
VBA テキストボックスの計算
-
11
エクセルVBA・時間値なら・・・
-
12
変数を文字列として扱う方法
-
13
16進数を10進数に簡単に変換す...
-
14
文字列から文字列を検索するプ...
-
15
■文字コード判定■
-
16
bashスクリプトでの文字列から...
-
17
sedなどで、特定の文字列の後の...
-
18
Left関数とRight関数を合わせた...
-
19
ファイルからデータを読み込み...
-
20
MS Wordのテキスト ボックス フ...
おすすめ情報
公式facebook
公式twitter