我曾使用 NSScanner 从下面的文本中检索数字。但有时结果并不像预期的那样。听说可用于 iOS 4 的 NSRegularExpression 类更好地进行这种类型的提取。由于我是 NSRegularExpression 的初学者,我发现 Apple 提供的文档很难理解。任何帮助将不胜感激。谢谢。
输入:
1D03 04 10 17 47 D24--
输出:
03 04 10 17 47 24
前 5 组数字应小于 59,最后一组应小于 39。
我曾使用 NSScanner 从下面的文本中检索数字。但有时结果并不像预期的那样。听说可用于 iOS 4 的 NSRegularExpression 类更好地进行这种类型的提取。由于我是 NSRegularExpression 的初学者,我发现 Apple 提供的文档很难理解。任何帮助将不胜感激。谢谢。
输入:
1D03 04 10 17 47 D24--
输出:
03 04 10 17 47 24
前 5 组数字应小于 59,最后一组应小于 39。
尝试这个 ..
NSString *originalString = @"1D03 04 10 17 47 D24---";
NSLog(@"%@", originalString);
NSMutableString *strippedString = [NSMutableString
stringWithCapacity:originalString.length];
NSScanner *scanner = [NSScanner scannerWithString:originalString];
NSCharacterSet *numbers = [NSCharacterSet
characterSetWithCharactersInString:@"0123456789 "];
while ([scanner isAtEnd] == NO) {
NSString *buffer;
if ([scanner scanCharactersFromSet:numbers intoString:&buffer]) {
[strippedString appendString:buffer];
} else {
[scanner setScanLocation:([scanner scanLocation] + 1)];
}
}
NSLog(@"%@", strippedString);
或这个:
NSString *string = @"1D03 04 10 17 47 D24---";
NSError *error = NULL;
NSRegularExpression *regex = [NSRegularExpression regularExpressionWithPattern:@"\\S*(\\d{2})\\S*"
options:NSRegularExpressionCaseInsensitive
error:&error];
NSString *modifiedString = [regex stringByReplacingMatchesInString:string
options:0
range:NSMakeRange(0, [string length])
withTemplate:@"$1"];
此正则表达式匹配以 0 个或多个非空格字符 (\S) 开头和结尾且中间有两位数字 (\d) 的所有内容。匹配项被字符串中间的两个数字替换。