meta data for this page
  •  

Dies ist eine alte Version des Dokuments!


String-Operationen

Leere Zeichenkette prüfen

Es gibt mehrere Möglichkeiten zu prüfen, ob eine Zeichenkette leer ist. Das Problem im Skripting ist jedoch, dass Variablen keinen festen Typ haben, sondern nur Variant-Datentypen sind. Einige Vorgehensweisen können aber auch hier übernommen werden.

Dim sString
sString = ""
'Möglichkeit 1
If sString = "" Then MsgBox "Leer"
'Möglichkeit 2
If StrComp(sString, "") = 0 Then MsgBox "Leer"
'Möglichkeit 3
If Len(sString) = 0 Then MsgBox "Leer"
If Len(sString) > 0 Then MsgBox "Variable enthält Daten"

Die effizientes Variante ist dabei Möglichkeit 3. Hier wird kein Vergleich durchgeführt, sondern nur die Länge, die im internen Variablenkopf gespeichert ist, geprüft. Sie ist sehr schnell.

Zeichenketten vergleichen

Auch hier gibt es verschiedene Möglichkeiten. Hier soll nur die vielseitigste Variante dargestellt werden, die sowohl mit als auch ohne Groß-/Kleinschreibung effektiv ist.

Dim sText
sText = "Vergleich"
'Vergleich unabhängig der Groß-/Kleinschreibung
If StrComp(sText, "vergleich", vbTextCompare) = 0 Then MsgBox "Gleich"
'Vergleich berücksichtigt Groß-/Kleinschreibung
If StrComp(sText, "Vergleich", vbBinaryCompare) = 0 Then MsgBox "Gleich"
 

Zeichenketten in Zahlen umwandeln

Der einfachste und schnellste Weg ist das Casting, also das direkte Umwandeln einer Zeichenkette in eine Zahl mittels Operator.

Option Explicit
Dim sZahl
Dim dZahl
Dim iZahl
Dim lZahl
'Achtung das Dezimalzeichen ist länderabhängig!
'In Deutschland in es das Komma
sZahl = "1234,23"
If IsNumeric(sZahl) Then
    'Konvertieren nach Double
    MsgBox VarName(CDbl(sZahl))
    'Konvertieren nach Single
    MsgBox VarName(CSng(sZahl))
    'Konvertieren nach Integer
    MsgBox VarName(CInt(sZahl))
    'Konvertieren nach Long
    MsgBox VarName(CLng(sZahl))
    'Konvertieren nach Currency
    MsgBox VarName(CCur(sZahl))
End If
Public Function VarName(vValue)
    Select Case VarType(vValue)
        Case vbVariant Or vbArray
            If UBound(vValue, 1) > -1 Then
                VarName = "Array: " & VarName(vValue(0))
            Else
                VarName = "Array: Variant - Länge 0"
            End If
        Case Else
            VarName = TypeName(vValue)
    End Select
End Function

Ländercode (Gebietsschema) berücksichtigen

Als Dezimaltrennzeichen wird je nach Gebietsschema entweder ein Komma (z. B. Deutschland) oder ein Punkt (z. B.englischer Sprachraum, Schweiz, Lichtenstein) verwendet. Das lokale Gebietsschema kann in VBScript mit der Funktion GetLocale ermittelt werden (s. Tabelle der Ländercodes).
Für fehlerfreie Berechnungen ist es daher ggf. erforderlich, bei Zahlenwerten, die in unter einem fremden Gebietsschema erzeugt wurde, dass Trennzeichen den Konventionen des lokalen Systems anzupassen.
Ein Bsp. ist die Verarbeitung von Exif-Werten, denn diese werden grundsätzlich mit einem Punkt als Trennzeichen gespeichert.

VBScript

Wert = FF_GetExifTag("ExposureBiasValue")                   ' Wert der Belichtungskorrektur auslesen, er ist stets mit Punkt getrennt
Gebietsschema = GetLocale                                   ' Gebietsschema des Systems ermitteln
if Gebietsschema <> 2055 and Gebietsschema <>  5127 Then    ' nicht Schweiz oder Lichtenstein, weil dort auch der Punkt gilt
     Wert = Replace (Wert, ".", ",")                        ' Punkt durch Komma ersetzen, damit Round funktioniert
End If
Korrekturwert = Round(Wert, 2)                              ' jetzt wird die Round erfolgreich ausgeführt

Teilstring löschen

Function DelPartString (Startstring, Delstring)
    ' löscht aus der Zeichekette 'Startstring' die Zeichenkette 'Delstring'
    ' es wird nur das erste Vorkommen von 'Delstring' berücksichtigt
    Dim i
    i = InStr (Startstring, Delstring)
    if i = 0 then Exit Function
    DelPartstring = Left (Startstring, i - 1) & Mid (Startstring, i + Len (Delstring))
End Function
 

Alternative:

VBScript:
sResult = Replace(sValue, sDelString, "", 1, 1, vbTextCompare)


JScript:
sResult = sValue.replace(sDelString,"");
 


String um eine bestimmte Zeichenzahl kürzen

Function Cut(p_Str,p_Cnt)
'schneidet vom String "p_Str" "p_Cnt" Zeichen ab
 Cut=Left(p_Str,Len(p_Str)-p_Cnt)
End Function

Teilstring zwischen Begrenzern herauslösen

Function MidString (String, Suchstring1, Suchstring2)
' gibt den Teilstring zwischen Suchstring1 und Suchstring2 zurück
' Bsp.: MidString("123[456]789","[","]") ergibt "456"
    MidString = Mid(String, Instr(String,Suchstring1)+1, Instr(String,Suchstring2)-Instr(String, Suchstring1)-1)
End Function



s. auch Pfad zerlegen