zoukankan      html  css  js  c++  java
  • 开发中常用的正则表达式

    为了能够更好地理解如何在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 Settingsuser1Desktop"; 
    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 = @"
    test
    "; 
    string r10 = Regex.Replace(t10, @"\n", "
    ");
    

    转换IP地址

    string t11 = "55.54.53.52"; 
    string p11 = "^" +    
         @"([01]?dd|2[0-4]d|25[0-5])." +    
         @"([01]?dd|2[0-4]d|25[0-5])." +    
         @"([01]?dd|2[0-4]d|25[0-5])." +    
         @"([01]?dd|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*
    ?
    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 = @"([^Wa-z0-9_]+)"; 
    MatchCollection mc15 = Regex.Matches(t15, p15);
    

    找出小写的单词

    string t16 = "This is A Test of lowercase"; 
    string p16 = @"([^WA-Z0-9_]+)"; 
    MatchCollection mc16 = Regex.Matches(t16, p16);
    

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

    string t17 = "This is A Test of Initial Caps"; 
    string p17 = @"([^Wa-z0-9_][^WA-Z0-9_]*)"; 
    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[^>]*?HREFs*=s*[""']?" + @"([^'"" >]+?)[ '""]?>"; 
    MatchCollection mc18 = Regex.Matches(t18, p18, "si");
    

    本文来自木庄网络博客> 开发中常用的正则表达式

  • 相关阅读:
    修改科目的字段状态组-OBC4
    采购收货-对于物料,在工厂、库存地点中不存在物料主数据
    采购收货
    新建工厂
    采购订单收货提示,T169P表不存在
    维护工厂日历
    开始创建物料没有选择会计视图,需要怎么维护
    拓端数据tecdat|R语言分布滞后线性和非线性模型(DLMs和DLNMs)分析时间序列数据
    拓端数据tecdat|R语言分布滞后非线性模型(DLNM)研究发病率,死亡率和空气污染示例
    拓端数据tecdat|R语言中实现广义相加模型GAM和普通最小二乘(OLS)回归
  • 原文地址:https://www.cnblogs.com/muzhuang/p/11715335.html
Copyright © 2011-2022 走看看