Live-Forum - Die aktuellen Beiträge
Anzeige
Archiv - Navigation
1888to1892
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
Inhaltsverzeichnis

Excel Makro Automatisches Tabellenblatt

Excel Makro Automatisches Tabellenblatt
24.06.2022 12:43:25
Patrick
Hallo Zusammen,
ich bin neu in diesem Forum und habe eine Frage zu VB Makros mit der Hoffnung, dass mir weitergeholfen werden kann.
Mein Ziel ist das automatische Anlegen von Tabellenblättern mit Makro.
Diese Tabellenblätter sollen auch direkt das Datum der jeweiligen Zelle übernehmen
Allerdings sind manche Zellen auf Grund einer WENN-Funktion leer, da ich nur bestimmte Wochentage in einem Monat benötige.
Je nachdem welchen Monat ich eingebe, ändern sich die leeren Zellen.
Ich erhalte immer einen Fehler bei "Tabelle.Name = Zelle.Text" wenn die Makro auf eine leere Zelle stößt.
Kann das Makro so geschrieben werden, dass die Zelle die durch die WENN-Funktion leer bleibt übersprungen wird, ohne zu versuchen hier ein Tabellenblatt zu erstellen?
Von A1:A42 stehen Tage - siehe Screenshot
Userbild
Hierfür habe ich folgenden Code benutzt:

Sub Blätter()
Dim Bereich As String
Dim Zelle As Range
Dim Tabelle As Worksheet
Bereich = "a1:a43"
With ActiveWorkbook
For Each Zelle In ActiveSheet.Range(Bereich).Cells
Set Tabelle = .Sheets.Add(After:=.Sheets(Sheets.Count))
Tabelle.Name = Zelle.Text
Next Zelle
End With
End Sub
Ich hoffe meine Beschreibung ist verständlich.
Lieben Dank.

4
Beiträge zum Forumthread
Beiträge zu diesem Forumthread

Betreff
Datum
Anwender
Anzeige
AW: Excel Makro Automatisches Tabellenblatt
24.06.2022 12:59:58
UweD
Hallo
dann so

            If Zelle.Text  "" Then Tabelle.Name = Zelle.Text
Bleibt aber das Problem, wenn das Blatt schon existiert
LG UweD
quatsch
24.06.2022 13:01:44
UweD
Das Blatt soll ja auch erst gar nicht entstehen.

Sub Blätter()
Dim Bereich As String
Dim Zelle As Range
Dim Tabelle As Worksheet
Bereich = "a1:a43"
With ActiveWorkbook
For Each Zelle In ActiveSheet.Range(Bereich).Cells
If Zelle.Text  "" Then
Set Tabelle = .Sheets.Add(After:=.Sheets(Sheets.Count))
Tabelle.Name = Zelle.Text
End If
Next Zelle
End With
End Sub

Anzeige
AW: quatsch
24.06.2022 13:19:19
Patrick
Hallo UweD,
vielen Dank für deine schnelle Rückmeldung.
Der Code funktioniert super.
So einfach kann es gehen, wenn man fit in VBA ist.
Ich bin begeistert, jetzt kann ich weiter arbeiten..
Mal sehen, auf welche Herausforderungen ich in meiner Exceltabelle noch stoße.
Ich wünsche dir einen schönen Tag.
Danke für die Rückmeldung (owT)
24.06.2022 13:26:59
UweD

303 Forumthreads zu ähnlichen Themen

Anzeige
Anzeige
Anzeige

Beliebteste Forumthreads (12 Monate)

Anzeige

Beliebteste Forumthreads (12 Monate)

Anzeige
Anzeige
Anzeige