Live-Forum - Die aktuellen Beiträge
Datum
Titel
17.04.2024 18:57:33
17.04.2024 16:56:58
Anzeige
Archiv - Navigation
1084to1088
Aktuelles Verzeichnis
Verzeichnis Index
Übersicht Verzeichnisse
Vorheriger Thread
Rückwärts Blättern
Nächster Thread
Vorwärts blättern
Anzeige
HERBERS
Excel-Forum (Archiv)
20+ Jahre Excel-Kompetenz: Von Anwendern, für Anwender
Zeilen löschen wenn ...
Marion65
Hallo zusammen,
habe mein Problem in der Beispieldatei beschrieben. Für Eure Hilfe wäre ich Dankbar.
Gruß Marion
https://www.herber.de/bbs/user/62728.xls
Ps. Franz hatte mir schon ein Makro gebastelt, doch leider funktioniert es nicht richtig.

Sub BegriffSuchenZeilenLoeschen()
Dim wks As Worksheet, lngZeile As Long, lngZeile1 As Long, lngZeile2 As Long
Dim varSuchen
Set wks = ActiveSheet
With wks
'Suchbegriff eingeben
varSuchen = InputBox("Suchwort?", "Wort suchen und Blöck löschen")
If varSuchen = False Or varSuchen = "" Or varSuchen = " " Then Exit Sub
'Inhalte aus Zellen mit nur Leerzeichen entfernen
For lngZeile = 1 To .Cells(.Rows.Count, 1).End(xlUp).Row
If Trim(.Cells(lngZeile, 1)) = "" Then
.Cells(lngZeile, 1).ClearContents
End If
Next
'Von unten aufwärts die letzte und 1. Zeile der Textblocke ermitteln _
und prüfen, ob Suchtext im Block enthalten
lngZeile = .Cells(.Rows.Count, 1).End(xlUp).Row
lngZeile2 = lngZeile 'letzte Textzeile
Do Until lngZeile = 1
'1. Zeile des Blocks ermitteln
Do Until .Cells(lngZeile, 1) = ""
If lngZeile = 1 Then
lngZeile1 = lngZeile
Exit Do
End If
lngZeile = lngZeile - 1
Loop
If lngZeile1  1 Then
lngZeile1 = lngZeile + 1
End If
'Block prüfen
If Not .Range(.Cells(lngZeile1, 1), .Cells(lngZeile2, 1)).Find(what:=varSuchen, _
LookIn:=xlValues, lookat:=xlPart) Is Nothing Then
.Range(.Rows(lngZeile1), .Rows(lngZeile2)).Delete shift:=xlShiftUp
End If
'letzte Zeile des vorherigen Blocks ermitteln
Do Until .Cells(lngZeile, 1)  ""
If lngZeile = 1 Then Exit Do
lngZeile = lngZeile - 1
Loop
lngZeile2 = lngZeile
Loop
End With
End Sub


7
Beiträge zum Forumthread
Beiträge zu diesem Forumthread

Betreff
Benutzer
Anzeige
AW: Zeilen löschen wenn ...
24.06.2009 20:27:47
chris
Hallo Marion,
habe hier mal was zusammengestellt.
Hilft dir das ?
Option Explicit

Sub BegriffSuchenZeilenLoeschen()
Dim wks As Worksheet, lngZeile As Long, lngZeile1 As Long, lngZeile2 As Long
Dim varSuchen
Dim wo
Dim cb As Range
Dim treffer As Integer
Dim anfang As Integer
Dim ende As Integer
Set wks = ActiveSheet
With wks
'Suchbegriff eingeben
varSuchen = "POST"
If varSuchen = False Or varSuchen = "" Or varSuchen = " " Then Exit Sub
'Inhalte aus Zellen mit nur Leerzeichen entfernen
For lngZeile = 1 To .Cells(.Rows.Count, 1).End(xlUp).Row
If Trim(.Cells(lngZeile, 1)) = "" Then
.Cells(lngZeile, 1).ClearContents
End If
Next
Set cb = .Cells.Find(what:=varSuchen, LookIn:=xlValues, lookat:=xlPart)
If Not cb Is Nothing Then
treffer = cb.Row
wo = cb.Row
Do Until .Cells(wo, 1) = ""
'letzte Zeile des vorherigen Blocks ermitteln
wo = wo - 1
Loop
anfang = wo + 1
Do Until .Cells(treffer, 1) = ""
'letzte Zeile des vorherigen Blocks ermitteln
treffer = treffer + 1
Loop
ende = treffer - 1
.Range(.Rows(anfang), .Rows(ende)).Delete shift:=xlShiftUp
Else
End If
End With
End Sub


Anzeige
AW: Zeilen löschen wenn ...
24.06.2009 20:52:15
Marion65
Hi Chris,
danke für Deine schnelle Antwort.
Mir wird dieser Fehler angezeigt:
'Inhalte aus Zellen mit nur Leerzeichen entfernen
For lngZeile = 1 To .Cells(.Rows.Count, 1).End(xlUp).Row
If Trim(.Cells(lngZeile, 1)) = "" Then
.Cells(lngZeile, 1).ClearContents
End If
Next
Man sollte sich nicht darauf verlassen dass Leerzeichen in den Zellen sind, aber man kann mit Bestimmtheit sagen, dass mindestens 2 Buchstaben und / oder 1 Zahl in den zu löschenden Zeilen vorkommt.
Gruß Marion
AW: Zeilen löschen wenn ...
24.06.2009 20:56:27
chris
Hallo Marion sorry aber bei mir kommt kein fehler ?
Ich kopiere meinen Code.Füge in ins Modul1 ein und starte den Code dann wird der block mit POST entfernt ?
Anzeige
AW: Zeilen löschen wenn ...
24.06.2009 21:07:13
Marion65
Hi Chris,
wenn es Dir nichts ausmacht, sende mir doch bitte mal Deine E-Mail-Adresse an: mohan87 (bei) gmx.de.
Ich sende Dir dann die Originaldatei zu.
Gruß Marion
Bib und Klasse
24.06.2009 21:10:10
{Boris}
Hi Marion,
gib mal die Bibliothek und die Klasse mit an:
If VBA.Strings.Trim(...) = ""
oder auch ohne die Klasse:
If VBA.Trim(...)
Grüße Boris
AW: Zeilen löschen wenn ...
24.06.2009 21:38:19
Gerd
Hallo Marion,
ergänze mal im Code von Franz oben
Dim Zelle as Range
und direkt unter "With wks"
For Each Zelle In .UsedRange
If Left$(Zelle, 1) = Chr(32) Then Zelle.Clear
Next
P.S.: Dass Du Leerzeichen in den "leeren" Zellen hast, hattest Du Franz wohl nicht mitgeteilt.
Gruß Gerd
Anzeige
AW: Zeilen löschen wenn ...
25.06.2009 00:01:03
Daniel
Hi
probier mal das Marko hier.
die Zeilen mit den Leerzeichen werden gelöscht, so daß mit .CurrentRegion der ganze Zellblock einfach gelöscht werden kann.

Sub test()
Dim strSuch As String
Dim rng As Range
'--- Leere Zeile wirklich Leeren
Columns(1).Insert
With Columns(2).SpecialCells(xlCellTypeConstants).Offset(0, -1)
.FormulaR1C1 = "=IF(LEN(SUBSTITUTE(RC[1],"" "",""""))=0,0,""x"")"
.SpecialCells(xlCellTypeFormulas, 1).Offset(0, 1).ClearContents
End With
Columns(1).Delete
'--- Suchtext eingeben
strSuch = InputBox("Suchtext")
'--- Block suchen und Löschen
Do
Set rng = Columns(1).Find(what:=strSuch, lookat:=xlPart, LookIn:=xlValues)
If rng Is Nothing Then Exit Do
rng.CurrentRegion.ClearContents
Loop
End Sub


Gruß, Daniel

Anzeige

311 Forumthreads zu ähnlichen Themen

Anzeige
Anzeige
Anzeige

Links zu Excel-Dialogen

Beliebteste Forumthreads (12 Monate)

Anzeige

Beliebteste Forumthreads (12 Monate)

Anzeige
Anzeige
Anzeige