欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

开发中常用的正则表达式

程序员文章站 2023-11-14 08:45:46
为了能够更好地理解如何在C 环境中使用正则表达式,这里整理了一些常用的正则表达式: 罗马数字 : 交换前两个单词位置 : 关健字=值 : 实现每行80个字符 : 月/日/年 小时:分:秒的时间格式 : 改变目录(仅适用于Windows平台) : 扩展16位转义符 : 删除C语言中的注释(有待完善) ......

为了能够更好地理解如何在c#环境中使用正则表达式,这里整理了一些常用的正则表达式:

罗马数字

string p1 = "^m*(d?c{0,3}|c[dm])" + "(l?x{0,3}|x[lc])(v?i{0,3}|i[vx])$";
string t1 = "v";
match m1 = regex.match(t1, p1);

开发中常用的正则表达式

交换前两个单词位置

string t2 = "the quick brown fox"; 
string p2 = @"(\s+)(\s+)(\s+)"; 
regex x2 = new regex(p2); 
string r2 = x2.replace(t2, "$3$2$1", 1);

开发中常用的正则表达式

关健字=值

string t3 = "myval = 3";
string p3 = @"(\w+)\s*=\s*(.*)\s*$";
match m3 = regex.match(t3, p3);

实现每行80个字符

string t4 = "********************" 
              + "******************************" 
              + "******************************"; 
string p4 = ".{80,}"; 
match m4 = regex.match(t4, p4);

月/日/年 小时:分:秒的时间格式

string t5 = "01/01/01 16:10:01"; 
string p5 = @"(\d+)/(\d+)/(\d+) (\d+):(\d+):(\d+)"; 
match m5 = regex.match(t5, p5);

改变目录(仅适用于windows平台)

string t6 = @"c:\documents and settings\user1\desktop\"; 
string r6 = regex.replace(t6,@"\\user1\\", @"\\user2\\");

扩展16位转义符

string t7 = "%41"; // capital a 
string p7 = "%([0-9a-fa-f][0-9a-fa-f])"; 
string r7 = regex.replace(t7, p7, hexconvert);

删除c语言中的注释(有待完善)

string t8 = @"    
    /*    
     * 传统风格的注释    
     */    
    "; 
   
    string p8 = @"    
     /\* # 匹配注释开始的定界符    
     .*? # 匹配注释    
     \*/ # 匹配注释结束定界符    
    ";    
    string r8 = regex.replace(t8, p8, "", "xs");

删除字符串中开始和结束处的空格

string t9a = " leading"; 
string p9a = @"^\s+"; 
string r9a = regex.replace(t9a, p9a, ""); 
string t9b = "trailing "; 
string p9b = @"\s+$"; 
string r9b = regex.replace(t9b, p9b, "");

在字符\后添加字符n,使之成为真正的新行

string t10 = @"\ntest\n"; 
string r10 = regex.replace(t10, @"\\n", "\n");

转换ip地址

string t11 = "55.54.53.52"; 
string p11 = "^" +    
     @"([01]?\d\d|2[0-4]\d|25[0-5])\." +    
     @"([01]?\d\d|2[0-4]\d|25[0-5])\." +    
     @"([01]?\d\d|2[0-4]\d|25[0-5])\." +    
     @"([01]?\d\d|2[0-4]\d|25[0-5])" +    
     "$"; 
match m11 = regex.match(t11, p11);

删除文件名包含的路径

string t12 = @"c:\file.txt"; 
string p12 = @"^.*\\"; 
string r12 = regex.replace(t12, p12, "");

联接多行字符串中的行

string t13 = @"this is    
    a split line";    
string p13 = @"\s*\r?\n\s*";    
string r13 = regex.replace(t13, p13, " ");

提取字符串中的所有数字

string t14 = @"    
    test 1    
    test 2.3    
    test 47    
    "; 
string p14 = @"(\d+\.?\d*|\.\d+)"; 
matchcollection mc14 = regex.matches(t14, p14);

找出所有的大写字母

string t15 = "this is a test of all caps"; 
string p15 = @"(\b[^\wa-z0-9_]+\b)"; 
matchcollection mc15 = regex.matches(t15, p15);

找出小写的单词

string t16 = "this is a test of lowercase"; 
string p16 = @"(\b[^\wa-z0-9_]+\b)"; 
matchcollection mc16 = regex.matches(t16, p16);

找出第一个字母为大写的单词

string t17 = "this is a test of initial caps"; 
string p17 = @"(\b[^\wa-z0-9_][^\wa-z0-9_]*\b)"; 
matchcollection mc17 = regex.matches(t17, p17);

找出简单的html语言中的链接

string t18 = @"    
    <html>    
    <a href=""first.htm"">first tag text</a>    
    <a href=""next.htm"">next tag text</a>    
    </html> 
       "; 
string p18 = @"<a[^>]*?href\s*=\s*[""']?" + @"([^'"" >]+?)[ '""]?>"; 
matchcollection mc18 = regex.matches(t18, p18, "si");

本文来自>