====== 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. [[http://msdn.microsoft.com/en-us/library/0h88fahh(v=vs.85).aspx|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
siehe auch [[Pfad zerlegen]]