Swift 正则表达式详解+实例

作者: Hellolad | 来源:发表于2018-04-03 09:28 被阅读85次

    语言:Swift 4.0.3

    正则表达式

    正则表达式是描述一些复杂逻辑的字符串的一种工具,在app开发中,常见于表单逻辑判断,如:手机号码,密码,身份证,邮箱等,本篇文章讲解一下在iOS开发中怎么使用正则表达式来处理表单逻辑。

    正则表达式怎么写推荐:正则表达式30分钟入门,这篇文章主要是记录iOS开发中怎么使用正则表达式。

    NSRegularExpression

    NSRegularExpression 在iOS中表现为迭代器方法,意思就是每当匹配到正确的匹配法则就会返回一部分给调用者。我使用NSRegularExpression提供的5中方法演示一下:

    1. numberOfMatches

    返回字符串中指定正则的匹配数,numberOfMatches通过你的调用会返回你指定的字符串中匹配到的匹配数量,具体我们看代码:

    let string = "12345a"
    let pattener = "[0-9]"
    let range = NSMakeRange(0, string.count)
    let result = try NSRegularExpression(pattern: pattener, options: [])
    let results = result.numberOfMatches(in: string, options: [], range: range)
    print(results)
    输出: 5
    

    我们定义了字符串"12345a",我们指定了匹配法则[0-9]就是说我们只仅仅匹配0-9的数字,所以就是匹配到了5个字符,numberOfMatches就这样用,我们然后再进行处理:

    if results == string.count {
        print(true)
    } else {
        print(false)
    }
    输出:false
    

    这样我们就可以知道我们所指定的字符串是否是NSRegularExpression能匹配正确的字符串,对于[0-9]正则而而言"12345a"显然不是的。

    2. matches

    返回一个数组其中包含字符串中正则表达式的所有匹配项,怎么理解?介绍NSRegularExpression已经说了,NSRegularExpression匹配是一个迭代器方法,每当匹配到正确的匹配法则就会返回一部分给调用者。我们看看代码就一目了然:

    let results = result.matches(in: string, options: [], range: range)
    for res in results {
        print(res.range)
    }
    输出:
    {0, 1}
    {1, 1}
    {2, 1}
    {3, 1}
    {4, 1}
    

    matches:返回的一个数组,里面是匹配到的是NSTextCheckingResult,我看了文档,但是我感觉它是你匹配到的字符的一个匹配项,再组合成数组,然后我们.range就能找到,匹配的位置所在,那这种怎么用于我们表单逻辑处理呢?看代码:

    var str = ""
    for res in results {
        str += (string as NSString).substring(with: res.range)
        print(str)
    }
    if str == string {
        print(true)
    } else {
        print(false)
    }
    输出:
    1
    12
    123
    1234
    12345
    false
    

    我们利用他的迭代器机制来使str叠加,最后再和元字符串作比较,以此来做到表单逻辑的判断。

    3. rangeOfFirstMatch

    返回正则表达式首次匹配的范围,这个相当有用,比如说我们要在一个字符串中查找一个字符的位置,我们就可以用rangeOfFirstMatch去做,那我们看看用正则怎么去做这件事情:

    let string = "a012345"
    let pattener = "[1-9]"
    let range = NSMakeRange(0, string.count)
    let result = try NSRegularExpression(pattern: pattener, options: [])
    let results = result.rangeOfFirstMatch(in: string, options: [], range: range)
    输出:{2,1}
    

    我们定义了字符串"a12345"然后我们指定了正则为[1-9],意思就是仅仅匹配从1-9的数字,最后打印的是{2,1}所以用rangeOfFirstMatch第一次匹配到数字是1不是0 ,所以位置就是{2,1}。

    4. firstMatch

    5. enumerateMatches

    这两种方法,具体我还没有仔细研究,前三种,已经差不多了够了,所以剩下的有机会补上吧。

    NSRegularExpression.Options

    在使用NSRegularExpression的时候的一种匹配选项.

    caseInsensitive
    allowCommentsAndWhitespace
    ignoreMetacharacters
    dotMatchesLineSeparators
    anchorsMatchLines
    useUnixLineSeparators
    useUnicodeWordBoundaries
    

    具体用法,就是看你的需求往NSRegularExpression里加就可以了。例如:

    /// 匹配不分大小写,接受注释和空格
    NSRegularExpression(pattern: pattener, options: [.caseInsensitive, .allowCommentsAndWhitespace])
    

    6.更Swifty的正则表达式函数

    swift中还提供了另一种好用的正则方式,就是String的range函数,它可以传入正则和一些其他参数来验证改字符串是否符合正则,正确的用法:

    let string = "a123"
    string.range(of: "\\d", options: .regularExpression, range: string.startIndex..<string.endIndex, locale: nil)
    

    使用区间string.startIndex..<string.endIndex来表示要验证的范围,最后得到一个Range<String.Index>,然后所有的代码:

    func check() -> Bool {
        let string = "a123"
        let range = string.range(of: "\\d", options: .regularExpression, range: string.startIndex..<string.endIndex, locale: nil)
        guard let r = range else {
            return false
        }
        if r.upperBound.encodedOffset == string.count {
            return true
        }
        return false
    }
    

    当r.upperBound.endcodedOffset=string.count的时候就意味着,正则从头扫描的尾部发现验证是通过的。想当前这个函数返回的一定是false,因为在验证第一个字符'a'的时候就已经验证通不过,所以就会提前结束,返回false,当我们把正则换成[a-zA-Z]?[0-9]{0,3}这样的,就会通过并返回true.
    --以此来记录 Swift NSRegularExpression and regularExpression ^ _^ --

    相关文章

      网友评论

        本文标题:Swift 正则表达式详解+实例

        本文链接:https://www.haomeiwen.com/subject/ztfqhftx.html