C # - Expressions régulières
UNE regular expressionest un modèle qui pourrait être comparé à un texte d'entrée. Le framework .Net fournit un moteur d'expression régulière qui permet une telle correspondance. Un modèle se compose d'un ou plusieurs littéraux de caractères, opérateurs ou constructions.
Constructions pour définir des expressions régulières
Il existe différentes catégories de caractères, d'opérateurs et de constructions qui vous permettent de définir des expressions régulières. Cliquez sur les liens suivants pour trouver ces constructions.
Le personnage s'échappe
Classes de caractères
Anchors
Regroupement des constructions
Quantifiers
Constructions de backreference
Constructions d'alternance
Substitutions
Constructions diverses
La classe Regex
La classe Regex est utilisée pour représenter une expression régulière. Il a les méthodes couramment utilisées suivantes -
N ° Sr. | Méthodes et description |
---|---|
1 | public bool IsMatch(string input) Indique si l'expression régulière spécifiée dans le constructeur Regex trouve une correspondance dans une chaîne d'entrée spécifiée. |
2 | public bool IsMatch(string input, int startat) Indique si l'expression régulière spécifiée dans le constructeur Regex trouve une correspondance dans la chaîne d'entrée spécifiée, en commençant à la position de départ spécifiée dans la chaîne. |
3 | public static bool IsMatch(string input, string pattern) Indique si l'expression régulière spécifiée trouve une correspondance dans la chaîne d'entrée spécifiée. |
4 | public MatchCollection Matches(string input) Recherche dans la chaîne d'entrée spécifiée toutes les occurrences d'une expression régulière. |
5 | public string Replace(string input, string replacement) Dans une chaîne d'entrée spécifiée, remplace toutes les chaînes qui correspondent à un modèle d'expression régulière par une chaîne de remplacement spécifiée. |
6 | public string[] Split(string input) Divise une chaîne d'entrée en un tableau de sous-chaînes aux positions définies par un modèle d'expression régulière spécifié dans le constructeur Regex. |
Pour la liste complète des méthodes et propriétés, veuillez lire la documentation Microsoft sur C #.
Exemple 1
L'exemple suivant correspond aux mots commençant par «S» -
using System;
using System.Text.RegularExpressions;
namespace RegExApplication {
class Program {
private static void showMatch(string text, string expr) {
Console.WriteLine("The Expression: " + expr);
MatchCollection mc = Regex.Matches(text, expr);
foreach (Match m in mc) {
Console.WriteLine(m);
}
}
static void Main(string[] args) {
string str = "A Thousand Splendid Suns";
Console.WriteLine("Matching words that start with 'S': ");
showMatch(str, @"\bS\S*");
Console.ReadKey();
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, il produit le résultat suivant -
Matching words that start with 'S':
The Expression: \bS\S*
Splendid
Suns
Exemple 2
L'exemple suivant fait correspondre les mots commençant par «m» et se terminant par «e» -
using System;
using System.Text.RegularExpressions;
namespace RegExApplication {
class Program {
private static void showMatch(string text, string expr) {
Console.WriteLine("The Expression: " + expr);
MatchCollection mc = Regex.Matches(text, expr);
foreach (Match m in mc) {
Console.WriteLine(m);
}
}
static void Main(string[] args) {
string str = "make maze and manage to measure it";
Console.WriteLine("Matching words start with 'm' and ends with 'e':");
showMatch(str, @"\bm\S*e\b");
Console.ReadKey();
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, il produit le résultat suivant -
Matching words start with 'm' and ends with 'e':
The Expression: \bm\S*e\b
make
maze
manage
measure
Exemple 3
Cet exemple remplace un espace blanc supplémentaire -
using System;
using System.Text.RegularExpressions;
namespace RegExApplication {
class Program {
static void Main(string[] args) {
string input = "Hello World ";
string pattern = "\\s+";
string replacement = " ";
Regex rgx = new Regex(pattern);
string result = rgx.Replace(input, replacement);
Console.WriteLine("Original String: {0}", input);
Console.WriteLine("Replacement String: {0}", result);
Console.ReadKey();
}
}
}
Lorsque le code ci-dessus est compilé et exécuté, il produit le résultat suivant -
Original String: Hello World
Replacement String: Hello World