Beispiel für reguläre Ausdrücke: Ändern von Datumsformaten
Im folgenden Codebeispiel wird die Regex.Replace-Methode verwendet, um Datumsangaben im Format mm/tt/jj durch Datumsangaben im Format tt-mm-jj zu ersetzen.
Warnung
Übergeben Sie ein Timeout, wenn Sie System.Text.RegularExpressions zum Verarbeiten nicht vertrauenswürdiger Eingaben verwenden. Böswillige Benutzer können Eingaben für RegularExpressions
bereitstellen, um einen Denial-of-Service-Angriff durchzuführen. ASP.NET Core-Framework-APIs, die RegularExpressions
verwenden, übergeben ein Timeout.
Beispiel
static string MDYToDMY(string input)
{
try {
return Regex.Replace(input,
@"\b(?<month>\d{1,2})/(?<day>\d{1,2})/(?<year>\d{2,4})\b",
"${day}-${month}-${year}", RegexOptions.None,
TimeSpan.FromMilliseconds(150));
}
catch (RegexMatchTimeoutException) {
return input;
}
}
Function MDYToDMY(input As String) As String
Try
Return Regex.Replace(input, _
"\b(?<month>\d{1,2})/(?<day>\d{1,2})/(?<year>\d{2,4})\b", _
"${day}-${month}-${year}", RegexOptions.None,
TimeSpan.FromMilliseconds(150))
Catch e As RegexMatchTimeoutException
Return input
End Try
End Function
Der folgende Code zeigt, wie die MDYToDMY
-Methode in einer Anwendung aufgerufen werden kann.
using System;
using System.Globalization;
using System.Text.RegularExpressions;
public class Class1
{
public static void Main()
{
string dateString = DateTime.Today.ToString("d",
DateTimeFormatInfo.InvariantInfo);
string resultString = MDYToDMY(dateString);
Console.WriteLine("Converted {0} to {1}.", dateString, resultString);
}
static string MDYToDMY(string input)
{
try {
return Regex.Replace(input,
@"\b(?<month>\d{1,2})/(?<day>\d{1,2})/(?<year>\d{2,4})\b",
"${day}-${month}-${year}", RegexOptions.None,
TimeSpan.FromMilliseconds(150));
}
catch (RegexMatchTimeoutException) {
return input;
}
}
}
// The example displays the following output to the console if run on 8/21/2007:
// Converted 08/21/2007 to 21-08-2007.
Imports System.Globalization
Imports System.Text.RegularExpressions
Module DateFormatReplacement
Public Sub Main()
Dim dateString As String = Date.Today.ToString("d", _
DateTimeFormatInfo.InvariantInfo)
Dim resultString As String = MDYToDMY(dateString)
Console.WriteLine("Converted {0} to {1}.", dateString, resultString)
End Sub
Function MDYToDMY(input As String) As String
Try
Return Regex.Replace(input, _
"\b(?<month>\d{1,2})/(?<day>\d{1,2})/(?<year>\d{2,4})\b", _
"${day}-${month}-${year}", RegexOptions.None,
TimeSpan.FromMilliseconds(150))
Catch e As RegexMatchTimeoutException
Return input
End Try
End Function
End Module
' The example displays the following output to the console if run on 8/21/2007:
' Converted 08/21/2007 to 21-08-2007.
Kommentare
Das Muster für reguläre Ausdrücke \b(?<month>\d{1,2})/(?<day>\d{1,2})/(?<year>\d{2,4})\b
wird entsprechend der folgenden Tabelle interpretiert:
Muster | Beschreibung |
---|---|
\b |
Der Vergleich beginnt an einer Wortgrenze. |
(?<month>\d{1,2}) |
Entsprechung für eine oder zwei Dezimalstellen finden. Dies ist die erfasste Gruppe month . |
/ |
Entsprechung für den Schrägstrich finden. |
(?<day>\d{1,2}) |
Entsprechung für eine oder zwei Dezimalstellen finden. Dies ist die erfasste Gruppe day . |
/ |
Entsprechung für den Schrägstrich finden. |
(?<year>\d{2,4}) |
Entsprechung für zwei bis vier Dezimalstellen finden. Dies ist die erfasste Gruppe year . |
\b |
Der Vergleich endet an einer Wortgrenze. |
Das Muster ${day}-${month}-${year}
definiert die Ersetzungszeichenfolge wie in der folgenden Tabelle gezeigt.
Muster | BESCHREIBUNG |
---|---|
$(day) |
Zeichenfolge hinzufügen, die von der Erfassungsgruppe day erfasst wurde. |
- |
Bindestrich hinzufügen. |
$(month) |
Zeichenfolge hinzufügen, die von der Erfassungsgruppe month erfasst wurde. |
- |
Bindestrich hinzufügen. |
$(year) |
Zeichenfolge hinzufügen, die von der Erfassungsgruppe year erfasst wurde. |