Thema Datum  Von Nutzer Rating
Antwort
23.12.2016 13:50:43 Simon
NotSolved
23.12.2016 14:49:40 Gast88391
NotSolved
27.12.2016 09:35:52 Simon
NotSolved
29.12.2016 15:12:20 Onur
NotSolved
28.12.2016 15:14:09 Simon
NotSolved
29.12.2016 16:06:02 Gast68970
NotSolved
30.12.2016 12:18:30 Simon
NotSolved
Blau Vereinfachungsmakro - Datenbereinigung
31.12.2016 09:06:33 Gast47217
NotSolved
29.12.2016 17:13:02 Onur
NotSolved

Ansicht des Beitrags:
Von:
Gast47217
Datum:
31.12.2016 09:06:33
Views:
720
Rating: Antwort:
  Ja
Thema:
Vereinfachungsmakro - Datenbereinigung

Moin!

HIer eine geänderte Variante. In meinem Test wird auch die Formel eingetragen. Das hängt aber davon ab, ob nach dem Löschen in Spalte F noch was steht. Nur dann wird eine Formel eingetragen. Die sieht dann so aus: =(D2-(F2*-1000/C2))/(F2*-1000/C2)

Habe sie jetzt noch gelb markiert, damit man erkennt wo sie eingetragen wurde. Sollte die letzte Spalte sein, die sich das Programm selber raussucht.

VG

Sub zeilen_löschen()
'löscht bestimmte Zeilen nach voragben
Dim farbe As Long
Dim bla As Variant
Dim zeilenanzahl As Long
Dim quelltab As Object
Dim zeile As Long
Dim neublatt As Boolean
Dim neu As Object
Dim letztespalte As Long
Dim blattname As String
Dim löschen As Range
Dim formel As String

Application.ScreenUpdating = False
'werte festlegen
Set quelltab = ActiveWorkbook.Worksheets("Reporting")
farbe = 43  'grün, ggf. anpassen
bla = "irgendwas"
neublatt = False
blattname = "NeuesBlatt"
Set löschen = Union(quelltab.Columns(4), quelltab.Columns("F:L"), quelltab.Columns("N:Y"), quelltab.Columns(27))

zeilenanzahl = quelltab.UsedRange.Rows.Count

'alle Zeilen durchgehen
For zeile = zeilenanzahl To 2 Step -1
    If quelltab.Cells(zeile, 1).Interior.ColorIndex = farbe Or quelltab.Cells(zeile, 2) = bla Or quelltab.Cells(zeile, 2) = "" Then
        quelltab.Rows(zeile).Delete
    Else
        'Prüfung auf 0 und dann kopieren
        If quelltab.Cells(zeile, 6) = 0 Then
            'Prüfung ob das Blatt schon eingefügt wurde
            If neublatt = False Then
                Set neu = ActiveWorkbook.Worksheets.Add(after:=Worksheets(Worksheets.Count))
                neu.Name = blattname
                quelltab.Select
                quelltab.Rows(1).Copy neu.Cells(1, 1)
                neublatt = True
            End If
            
            'kopieren
            neu.Rows("2").Insert Shift:=xlDown
            quelltab.Rows(zeile).Copy neu.Cells(2, 1)
            quelltab.Rows(zeile).Delete
        End If
    End If
Next zeile

'löschen
löschen.Delete

If neublatt = True Then
    Set löschen = Union(neu.Columns(4), neu.Columns("F:L"), neu.Columns("N:Y"), neu.Columns(27))
    löschen.Delete
End If
'nochmal die Werte anpassen
letztespalte = quelltab.UsedRange.Columns.Count + 1
zeilenanzahl = quelltab.UsedRange.Rows.Count
'Formel eintragen

For zeile = zeilenanzahl To 2 Step -1
    formel = "=(D" & zeile & "-(F" & zeile & "*-1000/C" & zeile & "))/(F" & zeile & "*-1000/C" & zeile & ")"
    If quelltab.Cells(zeile, 6) <> 0 Then
        quelltab.Cells(zeile, letztespalte).FormulaLocal = formel
        quelltab.Cells(zeile, letztespalte).Interior.ColorIndex = 6
    End If
Next zeile

Application.ScreenUpdating = True
End Sub

 


Ihre Antwort
  • Bitte beschreiben Sie Ihr Problem möglichst ausführlich. (Wichtige Info z.B.: Office Version, Betriebssystem, Wo genau kommen Sie nicht weiter)
  • Bitte helfen Sie ebenfalls wenn Ihnen geholfen werden konnte und markieren Sie Ihre Anfrage als erledigt (Klick auf Häckchen)
  • Bei Crossposting, entsprechende Links auf andere Forenbeiträge beifügen / nachtragen
  • Codeschnipsel am besten über den Code-Button im Text-Editor einfügen
  • Die Angabe der Emailadresse ist freiwillig und wird nur verwendet, um Sie bei Antworten auf Ihren Beitrag zu benachrichtigen
Thema: Name: Email:



  • Bitte beschreiben Sie Ihr Problem möglichst ausführlich. (Wichtige Info z.B.: Office Version, Betriebssystem, Wo genau kommen Sie nicht weiter)
  • Bitte helfen Sie ebenfalls wenn Ihnen geholfen werden konnte und markieren Sie Ihre Anfrage als erledigt (Klick auf Häckchen)
  • Bei Crossposting, entsprechende Links auf andere Forenbeiträge beifügen / nachtragen
  • Codeschnipsel am besten über den Code-Button im Text-Editor einfügen
  • Die Angabe der Emailadresse ist freiwillig und wird nur verwendet, um Sie bei Antworten auf Ihren Beitrag zu benachrichtigen

Thema Datum  Von Nutzer Rating
Antwort
23.12.2016 13:50:43 Simon
NotSolved
23.12.2016 14:49:40 Gast88391
NotSolved
27.12.2016 09:35:52 Simon
NotSolved
29.12.2016 15:12:20 Onur
NotSolved
28.12.2016 15:14:09 Simon
NotSolved
29.12.2016 16:06:02 Gast68970
NotSolved
30.12.2016 12:18:30 Simon
NotSolved
Blau Vereinfachungsmakro - Datenbereinigung
31.12.2016 09:06:33 Gast47217
NotSolved
29.12.2016 17:13:02 Onur
NotSolved