Live-Forum - Die aktuellen Beiträge
Datum
Titel
20.09.2024 17:13:00
20.09.2024 12:47:14
Anzeige
Anzeige
HERBERS
Excel-Forum (Archiv)
20+ Jahre Excel-Kompetenz: Von Anwendern, für Anwender Navigationstipps
Inhaltsverzeichnis

VBA Lösung für Tabellenblattwechsel gesucht

VBA Lösung für Tabellenblattwechsel gesucht
14.08.2008 10:07:25
Nila
Hallo.
Ich habe folgendes vor:
Ich lege derzeit eine Exceldatei mit Steckbriefen von ca. 150 Personen an.
Jeder Steckbrief steht dabei auf einem eigenen Tabellenblatt.
Die Tabellenblätter werden nach der entsprechenden Person benannt.
Zum Beispiel: Name von Tabellenblatt 70: "Maier, A."
Auf Blatt 2, welches "Suchmaske" heißen soll habe ich in Zelle D9 eine Gültigkeitsliste mit den
Namen und mit Dropdown hinterlegt, über welche die jeweilige person ausgwählt werden kann.
So kann zum Beispiel "Maier, A." ausgewählt werden.
Über einen Commandbutton soll nun das Tabellenblatt "Maier, A." angesteuert werden.
Bisherige Lösung:

Sub Suche()
Sheets("Suchmaske").Select
If Range("D9") = "Maier, A." Then
Sheets("Maier, A.").Select
End If
If Range("D9") = "..." Then
Sheets("...").Select
End If
End Sub



So müsste ich dies aber für jede Person einzeln schreiben.
Gibt es hierfür eine bessere Lösung?

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

Betreff
Datum
Anwender
Anzeige
AW: VBA Lösung für Tabellenblattwechsel gesucht
14.08.2008 10:15:14
Rudi
Hallo,
ganz einfach
sheets(Range("D9")).select
Gruß
Rudi

AW: VBA Lösung für Tabellenblattwechsel gesucht
14.08.2008 10:15:46
AndrRo
Hallo Nila,
versuch mal die kurzversion

Sub suchen
on error goto Fehler
sheets([D9]).select
exit sub
Fehler:
MSGBOX("Blatt existiert nicht")
End Sub


gruss
AndrRo

AW: VBA Lösung für Tabellenblattwechsel gesucht
14.08.2008 11:24:43
Nila
Hallo.
Erstmal Vielen Dank für die schnellen Antworten.
@ AndrRo:
Bei dieser Lösung bekomme ich als Ergebnis immer
MSGBOX("Blatt existiert nicht")
@ Rudi:
Bei dieser Lösung kommt immer die Fehlermeldung:
"Typen unverträglich"

Sub Suche()
Sheets(Range("D9")).Select
End Sub


Grüße

Anzeige
AW: VBA Lösung für Tabellenblattwechsel gesucht
14.08.2008 11:42:00
AndrRo
Hallo Nila
So funktioniert es:

Sub suchen()
On Error GoTo Fehler
Suchname = [d2]
Sheets(Suchname).Select
Exit Sub
Fehler:
MsgBox ("Blatt existiert nicht")
End Sub


gruss
Andreas

AW: VBA Lösung für Tabellenblattwechsel gesucht
14.08.2008 11:47:23
Ramses
Hallo
Es geht auch ohne Variable

Private Sub CommandButton1_Click()
On Error GoTo Fehler
Sheets([D2].Text).Select
Exit Sub
Fehler:
MsgBox ("Blatt existiert nicht")
End Sub


Gruss Rainer

AW: VBA Lösung für Tabellenblattwechsel gesucht
14.08.2008 11:47:30
Nila
Funktioniert super.
Genau das was ich gesucht habe.
Vielen Dank.
Grüße

Anzeige
AW: VBA Lösung für Tabellenblattwechsel gesucht
14.08.2008 11:43:53
Ramses
Hallo
WAS steht denn in D9 wirklich ? !!!
Stimmen die Bezeichnungen 100% überein ?
Wenn im Tabellenamen ein Leerzeichen zuviel drin ist, dann kracht es schon.
Mach doch gleich ein Inhaltsverzeichnis mit Hyperlinks das ist übersichtlicher und verhindert Fehler im schreiben
Sub Create_Hyperlink_Table_of_Contents()
    '(C) Ramses
    'Erstellt ein Inhaltsverzeichnis auf alle Tabellen einer
    'Mappe mit Hyperlinks auf die jeweiligen Tabellen
    Dim tarWks As Worksheet
    Dim i As Integer, myRow As Integer, tmpCnt As Integer
    'Blattnamen anpassen
    Set tarWks = Worksheets("Inhalt")
    'Bestehenden Inhalt löschen
    tarWks.Columns(1).ClearContents
    tarWks.Cells(1, 1) = "Inhalt"
    'Erstellen des Inhaltsverzeichnisses
    '**************************
    'Vertikal
    For i = 2 To Worksheets.count
        tarWks.Cells(i, 1) = Worksheets(i).name
        Cells(i, 1).Hyperlinks.Add Anchor:=Cells(i, 1), Address:="", SubAddress:="'" & Worksheets(i).name & "'!A1", TextToDisplay:=Worksheets(i).name
    Next i
    'Sortiert das Inhaltsverzeichnis
    tarWks.Columns(1).Sort Key1:=tarWks.Range("A1"), Order1:=xlAscending, Header:=xlGuess, _
    OrderCustom:=1, MatchCase:=False, Orientation:=xlTopToBottom, _
    DataOption1:=xlSortNormal
    '**************************
    'Horizontal
    'tmpCnt = 1
    'myRow = 1
    'For i = 1 To Worksheets.Count
    ' If i Mod 256 = 0 Then
    ' tmpCnt = 1
    ' myRow = myRow + 1
    ' End If
    ' If Worksheets(i).Name <> tarwks.Name Then
    ' tarwks.Cells(myRow, tmpCnt) = Worksheets(i).Name
    ' Cells(myRow, tmpCnt).Hyperlinks.Add Anchor:=Cells(myRow, tmpCnt), Address:="", SubAddress:="'" & Worksheets(i).Name & "'!A1", TextToDisplay:=Worksheets(i).Name
    ' tmpCnt = tmpCnt + 1
    ' End If
    'Next i
End Sub

Gruss Rainer
Anzeige

308 Forumthreads zu ähnlichen Themen

Anzeige
Anzeige
Anzeige

Links zu Excel-Dialogen

Beliebteste Forumthreads (12 Monate)

Anzeige

Beliebteste Forumthreads (12 Monate)

Anzeige
Anzeige
Anzeige