2015-07-19 60 views
4

我想解析一个字符串使用一个正则表达式模式。NSRegularExpression找不到捕获组匹配

下面是模式:

(\")(.+)(\")\s*(\{) 

这里要分析的文本:

"base" { 

我想找到这4个捕获组:

1. " 
2. base 
3. " 
4. { 

我使用试图捕获这些群组的下列代码

class func matchesInCapturingGroups(text: String, pattern: String) -> [String] { 
    var results = [String]() 

    let textRange = NSMakeRange(0, count(text)) 
    var index = 0 

    if let matches = regexp(pattern)?.matchesInString(text, options: NSMatchingOptions.ReportCompletion, range: textRange) as? [NSTextCheckingResult] { 
     for match in matches { 
      // this match = <NSExtendedRegularExpressionCheckingResult: 0x7fac3b601fd0>{0, 8}{<NSRegularExpression: 0x7fac3b70b5b0> (")(.+)(")\s*(\{) 0x1} 
      results.append(self.substring(text, range: match.range)) 
     } 
    } 

    return results 
} 

不幸的是,它只能找到一个范围为(0, 8)的组,它等于:"base" {。所以它发现一个组是整个字符串而不是4个组。

是否有可能使用NSRegularExpression

+1

@stribizhev你也必须将'\ s'转义为'\\ s'。 – luk2302

+0

我自己并没有这样做,但从NSTextCheckingResult的文档中,我不得不问:你有没有试过检查'match.numberOfRanges'和'match.rangeAtIndex'? –

+0

@ luk2302,是的,我知道,我在复制表达式时将它从regex101.com复制粘贴,所以它没有被转义。 –

回答

6

是的,当然这是可能的。你只需要改变当前的逻辑寻找实际的群体:

func matchesInCapturingGroups(text: String, pattern: String) -> [String] { 
    var results = [String]() 

    let textRange = NSMakeRange(0, text.lengthOfBytesUsingEncoding(NSUTF8StringEncoding)) 

    do { 
     let regex = try NSRegularExpression(pattern: pattern, options: []) 
     let matches = regex.matchesInString(text, options: NSMatchingOptions.ReportCompletion, range: textRange) 

     for index in 1..<matches[0].numberOfRanges { 
      results.append((text as NSString).substringWithRange(matches[0].rangeAtIndex(index))) 
     } 
     return results 
    } catch { 
     return [] 
    } 
} 

let pattern = "(\")(.+)(\")\\s*(\\{)" 
print(matchesInCapturingGroups("\"base\" {", pattern: pattern)) 

你居然只得到1场。你必须进入那场比赛,在那里你会发现被捕获的组。请注意,由于第一组代表整个比赛,因此我省略了第一组。

这将输出

[ “” “ ”基地“ ”“”, “{”]

注逃脱正则表达式的字符串,并确保您使用的是相同的一。

+0

谢谢你。好吧,我想我应该得到多个比赛,但有一个比赛与多个范围。现在很清楚。 –