Excel Worksheets markieren per ComboBox
Hallo,
seit paar Tage trette ich auf der stelle, mein Problem ist folgender.
Ich habe eine Excel Datei (.xlsm) mit ein paar Hundert Tabellenblättern. Der Name der Tabellenblätter ist nicht einheitlich (zb. ABC1, Blub1, XYZ2, foobar2 usw. usf.)
Ich habe zwei ComboBox'en beide fülle ich mit den Namen der Tabellenblätter und dann möchte in den Sheets Bereich zwischen ComboBox1 und ComboBox2 markieren, sprich ich wähle in der ComboBox zb. Sheet xyz1 und xyz40 und alle diese Sheets möchte ich markieren.
Für das laden der Beiden ComboBox'en nutze ich folgenden Code:
Jetzt möchte ich per Button, die vorgenommene Auswahl der Tabellenblätter markieren, später Strg + P und Drucken.
Vielleicht kann mir jemand weiterhelfen mit dem fehlenden Puzzle.
Danke
seit paar Tage trette ich auf der stelle, mein Problem ist folgender.
Ich habe eine Excel Datei (.xlsm) mit ein paar Hundert Tabellenblättern. Der Name der Tabellenblätter ist nicht einheitlich (zb. ABC1, Blub1, XYZ2, foobar2 usw. usf.)
Ich habe zwei ComboBox'en beide fülle ich mit den Namen der Tabellenblätter und dann möchte in den Sheets Bereich zwischen ComboBox1 und ComboBox2 markieren, sprich ich wähle in der ComboBox zb. Sheet xyz1 und xyz40 und alle diese Sheets möchte ich markieren.
Für das laden der Beiden ComboBox'en nutze ich folgenden Code:
Private Sub UserForm_Initialize()
Dim i As Integer
With Worksheets("ErstesSheet")
Me.ComboBox1.Clear
For i = 1 To ThisWorkbook.Worksheets.Count
Me.ComboBox1.AddItem Worksheets(i).Name
Next
Me.ComboBox2.Clear
For i = 1 To ThisWorkbook.Worksheets.Count
Me.ComboBox2.AddItem Worksheets(i).Name
Next
End With
End Sub
Vielleicht kann mir jemand weiterhelfen mit dem fehlenden Puzzle.
Danke
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 372756
Url: https://administrator.de/forum/excel-worksheets-markieren-per-combobox-372756.html
Ausgedruckt am: 19.01.2025 um 22:01 Uhr
5 Kommentare
Neuester Kommentar
Hast du dein Problem gelöst?
Dann musst du dir das Array zusammenstellen. Etwa so:
Steffen
Private Sub CommandButton1_Click()
Dim i As Long, idx As Long, arr() As String
idx = 0
For i = Worksheets(ComboBox1.Text).Index To Worksheets(ComboBox2.Text).Index
ReDim Preserve arr(idx)
arr(idx) = Worksheets(i).Name
idx = idx + 1
Next
Worksheets(arr).Select
End Sub
Steffen