zoukankan      html  css  js  c++  java
  • iOS谓词匹配字符串以及替换

    1.判断某个字符串是否符合某个正则表达式,通常用这个方法:

    // 判断字符串首字符是否为字母
    NSString *string = @"wo";
    // 1、准备正则式
    NSString *regex = @"^[A-Za-z]*$"; // 只能是字母,不区分大小写
    // 2、拼接谓词
    NSPredicate *predicateRe1 = [NSPredicate predicateWithFormat:@"self matches %@", regex];
    // 3、匹配字符串
    BOOL resualt = [predicateRe1 evaluateWithObject:string];
    NSLog(@"匹配结果%d", resualt);

    2.但是我们开发过程中也有可能遇到这种需求,匹配字符串并且找出符合正则的字符,并替换成其他的字符显示出来,这种情况下可以用这个方法:

    NSString *string = textField.text;

     // 1、准备正则式

        NSString *regex = @"[^\x00-\xff]|[{}()/]";

        

        NSString * replacement = @"";

        //    // 创建 NSRegularExpression 对象,匹配 正则表达式

        NSRegularExpression *regExp = [[NSRegularExpression alloc] initWithPattern:regex

                                                                           options:NSRegularExpressionCaseInsensitive

                                                                             error:nil];

        NSString *resultStr = string;

        // 替换匹配的字符串为 searchStr

        resultStr = [regExp stringByReplacingMatchesInString:string

                                                     options:NSMatchingReportProgress

                                                       range:NSMakeRange(0, string.length)

                                                withTemplate:replacement];

        NSLog(@"\nsearchStr = %@\nresultStr = %@",string,resultStr);

        textField.text = resultStr;

  • 相关阅读:
    HDU1294 Rooted Trees Problem(整数划分 组合数学 DP)
    HDU2546 饭卡(背包)
    经典动态规划总结
    POJ1285 Combinations, Once Again(背包 排列组合)
    计数 组合数学总结
    莫队算法 2038: [2009国家集训队]小Z的袜子(hose)
    循环-24. 求给定序列前N项和之二
    循环-23. 找完数
    循环-22. 输出闰年
    循环-21. 求交错序列前N项和
  • 原文地址:https://www.cnblogs.com/cui-cui/p/7512846.html
Copyright © 2011-2022 走看看