Ab VB6 gibt es ja bekanntlich die neuen Funktionen Split und Join. Jedoch scheint es manchmal umständlich, jedes Mal eine Variable zu deklarieren, die die Argumente hält. Beispiel: Anrede|Name|Straße|Plz|Ort|Land Sie möchten nun den Namen aus dem Gesamtstring ermitteln. Mittels Split würde das so aussehen: Dim sData() As String sData = Split(sString, "|") MsgBox "Name: " & sData(1) Mit nachfolgender Funktion ist es möglich, schnell und einfach ein Argument zurückzugeben, ohne den String erst aufteilen zu müssen. Außerdem ist diese Funktion auch für Versionen unter VB6 gültig. Public Function GetToken(sText As String, _ iPos As Integer, _ Optional sDelimiter As String = " ") As String Dim iTotal As Integer Dim iCurPos As Integer Dim iLastPos As Integer Dim sAttach As String ' Erstes Trennungszeichen suchen iLastPos = Len(sDelimiter) * -1 + 1 iCurPos = InStr(1, sText, sDelimiter) Do Until iCurPos = 0 iTotal = iTotal + 1 ' Trennungszeichen gefunden If iTotal >= iPos Then ' Gewünschte Position erreicht? Exit Do End If iLastPos = iCurPos iCurPos = InStr(iCurPos + 1, sText, sDelimiter) Loop ' Wenn kein Trennungszeichen gefunden wurde, ' kompletten Text zurückgeben If iCurPos = 0 And iPos = 1 Then sAttach = sText ' Falls gefunden, richtigen Parameter zurückgeben ElseIf iTotal = iPos Then sAttach = Mid$(sText, iLastPos + Len(sDelimiter), _ iCurPos - iLastPos - Len(sDelimiter)) ElseIf iTotal = iPos - 1 Then sAttach = Mid$(sText, iLastPos + Len(sDelimiter)) End If GetToken = sAttach End Function Auf unser obigens Beispiel bezogen, würde das Ermitteln des Namens aus dem Gesamtstring nun so aussehen: MsgBox GetToken(sString, 2, "|") Dieser Tipp wurde bereits 15.071 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 (einschl. Beispielprojekt!) 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. |
Neu! sevCommand 4.0 Professionelle Schaltflächen im modernen Design! Mit nur wenigen Mausklicks statten auch Sie Ihre Anwendungen ab sofort mit grafischen Schaltflächen im modernen Look & Feel aus (WinXP, Office, Vista oder auch Windows 8), inkl. große Symbolbibliothek. Tipp des Monats März 2024 Dieter Otter UTF-8 Konvertierung von Dateien und Strings VB6 selbst verfügt über keine Funktionen zur UTF-8 Konvertierung von Daten. Mit Hilfe des ADODB.Stream-Objekts lassen sich diese fehlenden Funktionen aber schnell nachrüsten. 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. |