Szukaj…


Składnia

  • NSRegularExpression * regex = [NSRegularExpression regularExpressionWithPattern: Opcje WZORU: Błąd OPCJI: BŁĄD];
  • NSArray <NSTextCheckingResult *> * results = [regex pasujeInString: opcje STRING: zakres OPCJE: RANGE_IN_STRING];
  • NSInteger numberOfMatches = [regex numberOfMatchesInString: opcje STRING: zakres OPCJE: RANGE_IN_STRING];

Znajdź wszystkie liczby w ciągu

NSString *testString = @"There are 42 sheep and 8672 cows.";
NSError *error = nil;
NSRegularExpression *regex = [NSRegularExpression regularExpressionWithPattern:@"(\\d+)"
                                                                       options:NSRegularExpressionCaseInsensitive
                                                                         error:&error];

NSArray *matches = [regex matchesInString:testString
                                  options:0
                                    range:NSMakeRange(0, testString.length)];

for (NSTextCheckingResult *matchResult in matches) {
    NSString* match = [testString substringWithRange:matchResult.range];
    NSLog(@"match: %@", match);
}

Dane wyjściowe będą match: 42 i match: 8672 .

Sprawdź, czy łańcuch pasuje do wzorca

NSString *testString1 = @"(555) 123-5678";
NSString *testString2 = @"not a phone number";

NSError *error = nil;
NSRegularExpression *regex = [NSRegularExpression regularExpressionWithPattern:@"^\\(\\d{3}\\) \\d{3}\\-\\d{4}$"
                                                                       options:NSRegularExpressionCaseInsensitive error:&error];

NSInteger result1 = [regex numberOfMatchesInString:testString1 options:0 range:NSMakeRange(0, testString1.length)];
NSInteger result2 = [regex numberOfMatchesInString:testString2 options:0 range:NSMakeRange(0, testString2.length)];

NSLog(@"Is string 1 a phone number? %@", result1 > 0 ? @"YES" : @"NO");
NSLog(@"Is string 2 a phone number? %@", result2 > 0 ? @"YES" : @"NO");

Dane wyjściowe pokażą, że pierwszy ciąg to numer telefonu, a drugi nie.



Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow