新版本的Delphi内置了专门用于正则操作的库System.RegularExpressions,该库提供了一个专门的类TRegEx用来操作正则表达式。今天一起来看看Delphi正则表达式用法,包括创建正则表达式对象、匹配验证、捕获分组以及反向引用等。 新建TRegEx对象通过TRegEx.Create('your pattern')来新建正则对象。 uses System.RegularExpressions;var Regex: TRegEx; Input: string;begin Input := 'Hello world and love'; // 创建一个正则表达式对象,使用构造函数指定正则表达式字符串 Regex := TRegEx.Create('world');end; 验证是否匹配(IsMatch)新建TRegEx对象之后,如果只需要验证是否匹配,可以使用IsMatch方法。该方法返回一个boolean值,true表示匹配,false表示不匹配。
获取第一个匹配的位置(Match)新建TRegEx对象之后,也可以用Match方法,获取到具体的匹配信息,包括第一次匹配的位置(Index)。 var Match: TMatch;begin Match := Regex.Match(Input); if Match.Success then ShowMessage('第一次匹配的位置在: ' + IntToStr(Match.Index));end; 获取所有匹配结果(Matches)如果要获取所有匹配结果,可以用Matches方法,该方法返回一个TMatchCollection,包含所有的匹配结果。
捕获分组(Groups)在正则表达式中,使用圆括号 () 来定义捕获组。每一个()表示一组匹配。匹配后,可以通过Groups获取到所有匹配的分组信息。 比如下面的案例,定义分组正则表达式,可以获取到所有的数字。 var Match: TMatch;begin Match := Regex.Match('123-45-6789'); if Match.Success then begin WriteLn('Group 1: ' + Match.Groups[1].Value); // 输出:123 WriteLn('Group 2: ' + Match.Groups[2].Value); // 输出:45 WriteLn('Group 3: ' + Match.Groups[3].Value); // 输出:6789 end;end; 匹配结果反向引用反向引用允许你在替换字符串中引用之前的捕获组内容,一般用于正则替换(Replace)场景。使用 $ 符号加组号(如 $1、$2)或命名组名(如 $groupname)来引用。 下面的案例中,<tag>text</tag>被替换成 $1 has been extracted,其中$1是匹配到的结果,即text。
|
|