Кажется, что nsscanner не может выполнить свою работу, когда сканирует динамически вводимую строку. Позвольте мне сначала написать мои коды:
NSString *setext = mySearchBar.text;
NSScanner *scanner = [NSScanner scannerWithString:setext];
NSString *a = @"a";
NSString *aa;
[scanner scanUpToString:a intoString:NULL];
while ([scanner isAtEnd] == NO)
{
if ( [scanner scanString:a intoString:NULL]);
{
NSLog (@" scan: %@ ", aa);
}
}
Я пробовал эти коды во многих методах, но я получаю тот же результат: симулятор завершил работу без каких-либо аварийных журналов, когда я что-то записывал в поисковой строке. mySearchBar добавляется программно и относится к классу UISearchBar и связан с самим собой.
Когда я пытался переписать setext в searchText в методе filterContent для поиска и сравнения, NSLog показывает бесконечное количество либо
- "scan: MainViewController"
или
- "сканирование: (первый введенный символ)"
а затем разбился. MainViewController относится к классу UIViewController.
Я пробовал эти коды из документации Apple;
http://developer.apple.com/library/mac/#documentation/Cocoa/Conceptual/Strings/Articles/Scanners.html
:
NSString *string = @"Product: Acme Potato Peeler; Cost: 0.98 73\n\
Product: Chef Pierre Pasta Fork; Cost: 0.75 19\n\
Product: Chef Pierre Colander; Cost: 1.27 2\n";
NSCharacterSet *semicolonSet;
NSScanner *theScanner;
NSString *PRODUCT = @"Product:";
NSString *COST = @"Cost:";
NSString *productName;
float productCost;
NSInteger productSold;
semicolonSet = [NSCharacterSet characterSetWithCharactersInString:@";"];
theScanner = [NSScanner scannerWithString:string];
while ([theScanner isAtEnd] == NO)
{
if ([theScanner scanString:PRODUCT intoString:NULL] &&
[theScanner scanUpToCharactersFromSet:semicolonSet
intoString:&productName] &&
[theScanner scanString:@";" intoString:NULL] &&
[theScanner scanString:COST intoString:NULL] &&
[theScanner scanFloat:&productCost] &&
[theScanner scanInteger:&productSold])
{
NSLog(@"Sales of %@: $%1.2f", productName, productCost * productSold);
}
}
и он отлично работает в любом методе. NSLog этого кода обнаружился один раз и отлично написан.
Но я не могу понять, почему этот код работает, а не мой.
Моя цель - обнаружить специальные символы в строке поиска. Если текст в строке поиска содержит такие символы, я могу отключить NSDiactricInsensitiveSearch
в NSComparisonResult
. Затем в результатах поиска будут отображаться слова, содержащие специальные символы, которые не являются частью диалектических символов.
РЕДАКТИРОВАТЬ 16 августа:
Хорошо, вот мои коды для nscomparisonresult. @JohnBrighton: решение работает, но nslog входит в цикл for, и я не могу нажать на что-либо в приложении для ввода первого символа, который я ввожу ... Если я вставлю эти коды перед циклом for, поиск не будет работать;
for (mystr in noWords) {
NSComparisonResult result;
NSString *string = mySearchBar.text;
NSRange range = [string rangeOfString:@"ø"];
if (range.location != NSNotFound) {
result = [mystr compare:searchText options:(NSCaseInsensitiveSearch)
range:NSMakeRange(0, [searchText length])];
NSLog (@" detected");
}
else
{
result = [mystr compare:searchText options:(NSCaseInsensitiveSearch|NSDiacriticInsensitiveSearch)
range:NSMakeRange(0, [searchText length])];
NSLog(@"normal");
}
if (result == NSOrderedSame)
{
[self.filteredListContent addObject:mystr];
}
}
РЕДАКТИРОВАТЬ 17 августа, переписать коды выше, так что весь метод виден:
- (void)filterContentForSearchText:(NSString*)searchText
{
for (mystr in noWords)
{
clock_t start = clock(), end;
NSComparisonResult result;
NSString *string = searchText;
NSRange range = [string rangeOfString:@"æ"];
NSRange range2 = [string rangeOfString:@"ø"];
NSRange range3 = [string rangeOfString:@"å"];
if (range.location != NSNotFound||range2.location != NSNotFound ||range3.location != NSNotFound ) {
// This means the character has been found.
// The position is at range.location.
result = [mystr compare:searchText options:(NSCaseInsensitiveSearch)
range:NSMakeRange(0, [searchText length])];
}
else {
result = [mystr compare:searchText options:(NSCaseInsensitiveSearch|NSDiacriticInsensitiveSearch)
range:NSMakeRange(0, [searchText length])];
}
end = clock();
end = ((double)end - start) / CLOCKS_PER_SEC;
printf("Time taken: %f \n", (double)end);
if (result == NSOrderedSame)
{
[self.filteredListContent addObject:mystr];
}
}
}
Было получено бесконечное количество NSLogs, показывающих «Время истекло: 0» вместо «Время потрачено: 0.0000» из вашего предыдущего кода.