Dass man mit dem TreeView relativ einfach den Verzeichnisbaum anzeigen lassen kann zeigt uns klar dieser Tipp: Da ich aber oft die Pfade aus z.B. Emails kopiere und direkt in die Adresszeile meines Explorers einfüge, brauche ich eine Funktion, die dann genau die im Pfad enthaltenen Nodes expandiert (wie man es von Windows bereits kennt). Gegeben sind folgende Controls:
Sub TextBox4PreviewKeyDown(sender As Object, e As PreviewKeyDownEventArgs) ' Hier wird als Trigger das Drücken der Enter-Taste genutzt, wenn Textbox4 im Focus steht. If e.KeyCode = Keys.Enter Then ' Die "Startposition" wird festgelegt Dim NodCol As TreeNodeCollection = exploreR_TREEVIEW1.Nodes ' Wird nur benutzt falls der gegebene Pfad falsch ist und/oder nicht ' aufgelöst werden kann, zeigt den bisher gefundenen Pfad an. Dim Node As TreeNode ' Wird nur benutzt falls der gegebene Pfad falsch ist und/oder nicht aufgelöst ' werden kann, zeigt den gesuchten und ggf. fehlenden/falsch geschriebenen Unterordner an. Dim FolderIndex As Integer = 0 ' Der Pfad wird in "Unterordner" aufgesplittet Dim Tmpsplit As String() = textBox4.Text.Split(Convert.ToChar("\")) ' Da beim splitten alle BackSlashs ("\") entfernt werden, muss man es für ' den Laufwerksbuchstaben wieder einfügen. Tmpsplit(0) = Tmpsplit(0) & "\" ' In der Schleife wird Step-by-Step jeder "Unterordner" abgefragt For i As Integer = 0 To Tmpsplit.Length - 1 ' temporäre Kontrollvariable Dim TmpCount As Integer = 0 ' Für jeden "Unterordner" wird der Name der enthaltenen Nodes mit ' dem Namen des "Unterordners" verglichen. For Each Nod As TreeNode In NodCol ' Passt er, wird sofort das entsprechende TreeNode expandiert... If Tmpsplit(i) = Nod.Text Then Node = Nod Nod.Expand() ' ...seine ChildNodes eingelesen und als neue "Startposition" festgelegt. NodCol = Nod.Nodes TmpCount += 1 ' Falls der Ordner gefunden wurde kann vorzeitig abgebrochen werden. Exit For Else FolderIndex = i End If Next ' Hier wird abgefragt ob ein "Unterordner" gefunden wurde und falls ' nicht mit Fehlermelung abgebrochen If TmpCount = 0 Then MsgBox("Unterordner nicht gefunden!" & vbCrLf & "Gefundener Pfad: " & Node.FullPath & vbCrLf & _ "Gesuchter Unterordner: " & Chr(34) & Tmpsplit(FolderIndex) & Chr(34), MsgBoxStyle.Information) Exit Sub End If Next End If End Sub Dieser Tipp wurde bereits 8.483 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
sevZIP40 Pro DLL Zippen und Unzippen wie die Profis! Mit nur wenigen Zeilen Code statten Sie Ihre Anwendungen ab sofort mit schnellen Zip- und Unzip-Funktionen aus. Hierbei lassen sich entweder einzelnen Dateien oder auch gesamte Ordner zippen bzw. entpacken. Tipp des Monats April 2024 Skyfloy Chart von Microsoft und dazu noch gratis Tutorial für Microsoft Chart Controls für Microsoft .NET Framework 3.5 Access-Tools Vol.1 Über 400 MByte Inhalt Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |