Excelmania
Lieutenant
- Registriert
- Apr. 2010
- Beiträge
- 799
Hallo.
Ich habe eine Excel-Datei, die aus zwei Exporten aus zwei verschiedenen Datenbanken gespeist wird.
Die Daten werden für die Bearbeitung aufbereitet. Damit nur die Daten, die für die Organisationseinheiten relevant sind, auch diesen zugestellt werden, habe ich ein Makro erstellt mit dem das formelbasierte Tabellenblatt in eine eigene Excel-Datei kopiert wird.
Als Einzellösung klappt es auch. In einer Schleife kommt es jedoch zu einem Fehler.
Vielleicht könnte Ihr mir helfen?
Der Debugger bleibt bei ActiveWorkbook.SaveAs (strOrdner & "\Finanzauswertung-Auswertung - " & ActiveSheet.Range("B3").Value & " - " & ActiveSheet.Range("E3").Value & ".xlsx") hängen.
Ich habe eine Excel-Datei, die aus zwei Exporten aus zwei verschiedenen Datenbanken gespeist wird.
Die Daten werden für die Bearbeitung aufbereitet. Damit nur die Daten, die für die Organisationseinheiten relevant sind, auch diesen zugestellt werden, habe ich ein Makro erstellt mit dem das formelbasierte Tabellenblatt in eine eigene Excel-Datei kopiert wird.
Als Einzellösung klappt es auch. In einer Schleife kommt es jedoch zu einem Fehler.
Vielleicht könnte Ihr mir helfen?
Code:
Private Sub AW_OE_CB_Excelserie_Click()
Dim k As Integer
Dim varFilename As Variant
Dim objShape As Shape
TBName = ActiveSheet.Name
'Variablen Organisationseinheit
OeS = Worksheets("Optionen").Range("B12").Value
OeZ = Worksheets("Optionen").Range("B18").Value
OlZ = Worksheets("Optionen").Range("B19").Value
k = OeZ
'Variablen Ziel:AW_OE
ZeS = Worksheets("Optionen").Range("B71").Value
ZlS = Worksheets("Optionen").Range("B91").Value
ZeZ = Worksheets("Optionen").Range("B96").Value
ZlZ = Worksheets("Optionen").Range("B97").Value
With Application
.ScreenUpdating = False
.EnableEvents = False
.Calculation = xlCalculationAutomatic
End With
Dim strOrdner As String
With Application.FileDialog(msoFileDialogFolderPicker)
.InitialFileName = "C:\"
.Title = "Ordnerauswahl"
.ButtonName = "Auswahl..."
.InitialView = msoFileDialogViewList
If .Show = -1 Then
strOrdner = .SelectedItems(1)
If Right(strOrdner, 1) <> "\" Then strOrdner = strOrdner & "\"
'Schleife OE - Anfang
With Worksheets("Auswertung")
For k = OeZ To OlZ
.Range(OeS & k).Copy
Worksheets("AW_OE").Range("B3").PasteSpecial Paste:=xlPasteValues
Call AW_OE_anzeigen
'Tabellenblatt kopieren
Worksheets(TBName).Copy
Application.DisplayAlerts = False
'Schaltflächen löschen
For Each objShape In ActiveWorkbook.ActiveSheet.Shapes
If Not Application.Intersect(objShape.TopLeftCell, ActiveWorkbook.ActiveSheet.Range("O1:T20")) Is Nothing Then
objShape.Delete
End If
Next
'Formeln durch Festwerte ersetzen
ActiveWorkbook.ActiveSheet.Range("D6:O17").Copy
ActiveWorkbook.ActiveSheet.Range("D6:O17").PasteSpecial Paste:=xlValues
Application.CutCopyMode = False
'Dropdownauswahl löschen
Z = ActiveWorkbook.ActiveSheet.Range("B3").Value
ActiveWorkbook.ActiveSheet.Range("B3").Clear
ActiveWorkbook.ActiveSheet.Range("B3").Value = Z
X = ActiveWorkbook.ActiveSheet.Range("E3").Value
ActiveWorkbook.ActiveSheet.Range("E3:F3").Clear
ActiveWorkbook.ActiveSheet.Range("E3").Value = X
'Formatierung Stammdaten wiederherstellen
ActiveWorkbook.ActiveSheet.Range("E3,B3").Select
ActiveWorkbook.ActiveSheet.Range("B3").Activate
Selection.Borders(xlDiagonalDown).LineStyle = xlNone
Selection.Borders(xlDiagonalUp).LineStyle = xlNone
With Selection.Borders(xlEdgeLeft)
.LineStyle = xlContinuous
.ColorIndex = 0
.TintAndShade = 0
.Weight = xlHairline
End With
With Selection.Borders(xlEdgeTop)
.LineStyle = xlContinuous
.ColorIndex = 0
.TintAndShade = 0
.Weight = xlHairline
End With
With Selection.Borders(xlEdgeBottom)
.LineStyle = xlContinuous
.ColorIndex = 0
.TintAndShade = 0
.Weight = xlHairline
End With
With Selection.Borders(xlEdgeRight)
.LineStyle = xlContinuous
.ColorIndex = 0
.TintAndShade = 0
.Weight = xlHairline
End With
Selection.Borders(xlInsideVertical).LineStyle = xlNone
Selection.Borders(xlInsideHorizontal).LineStyle = xlNone
With Selection.Interior
.Pattern = xlSolid
.PatternColorIndex = xlAutomatic
.Color = 13434879
.TintAndShade = 0
.PatternTintAndShade = 0
End With
'Individuelle Flaz-Phasen ausblenden
ActiveWorkbook.ActiveSheet.Range("R:U").EntireColumn.Hidden = True
'Blattschutz setzen
ActiveWorkbook.ActiveSheet.Protect
'A1 auswählen
ActiveWorkbook.ActiveSheet.Range("A1").Select
'Speichern
ActiveWorkbook.SaveAs (strOrdner & "\Finanzauswertung-Auswertung - " & ActiveSheet.Range("B3").Value & " - " & ActiveSheet.Range("E3").Value & ".xlsx")
'Schließen
ActiveWorkbook.Close
'Schleife OE - Ende
Next k
End With
Else
strOrdner = ""
End If
End With
' A2 Selektieren
ActiveSheet.Range("A2").Select
With Application
.ScreenUpdating = False
.EnableEvents = False
.Calculation = xlCalculationAutomatic
End With
End Sub
Der Debugger bleibt bei ActiveWorkbook.SaveAs (strOrdner & "\Finanzauswertung-Auswertung - " & ActiveSheet.Range("B3").Value & " - " & ActiveSheet.Range("E3").Value & ".xlsx") hängen.