vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#

https://www.vbarchiv.net
Rubrik: Variablen/Strings · String-Operationen   |   VB-Versionen: VB621.09.09
Bedingte Textverkettung mit Trennzeichen

Eine Funktion um beliebig viele Texte zu verketten mit seinem jeweiligen Trennzeichen, welches nur dann verwenden wird, wenn der Text nicht leer ist.

Autor:   Jean Pierre AllainBewertung:  Views:  9.080 
www.abiss.deSystem:  Win9x, WinNT, Win2k, WinXP, Vista, Win7, Win8, Win10kein Beispielprojekt 

Häufig müssen Texte mit Trennzeichen Verkettet werden:

[Nachname] & ", " & [Vorname] -> "Allain, Jean Pierre"

Sollte allerdings das Feld [Vorname] null sein, erhält man folgendes:

"Allain, "

Mit IF oder IIF kann man diesen Fall abfangen.

Bei längeren Verkettung wie diese:

[Anrede] & " " & [Titel] & " " & [Vorname] & " " & [Nachname]

wird es schnell unübersichtlich.

Daher habe ich folgende Function dafür erstellt:

Public Function StrConcatDelim(ParamArray Text()) As String
  Dim tmp As String, i As Long
  tmp = Text(0) & ""
  For i = 1 To UBound(Text) Step 2
    If tmp = "" Or Text(i + 1) & "" = "" Then
      tmp = tmp & Text(i + 1)
    Else
      tmp = tmp & Text(i) & Text(i + 1)
    End If
  Next i
  StrConcatDelim = tmp
End Function

Aufrufbeispiel:

Dim sText As String
sText = StrConcatDelim([Anrede], " ", [Titel], " ", [Vorname], " ", [Nachname])
sText = StrConcatDelim([Nachname], ", ", [Vorname])

Beim Aufruf der Funktion ist darauf zu achten, mindestens 3 Parameter oder 5 oder 7 oder 9 usw.. Parameter zu übergeben.



Anzeige

Kauftipp Unser Dauerbrenner!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.
 
 
Copyright ©2000-2019 vb@rchiv Dieter OtterAlle Rechte vorbehalten.


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.