Выпуск iphone nscanner

Кажется, что 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"

или же

  • "scan: (первый символ, который я ввел)"

а потом разбился. 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];
        }
    }   
}

В результате появилось бесконечное количество NSLog s, показывающих "Время истекло: 0" вместо "Время потрачено: 0,0000" из вашего предыдущего кода.

1 ответ

Решение

Вы пытаетесь распечатать "аа", чего вы не хотите, так как вы только что объявили это. Инициализируйте это / распечатайте что-нибудь еще, и это будет работать.

Изменить: вот хороший способ определить, если | строка | содержит "!".

NSString *string = @"it works!";
NSRange range = [string rangeOfString:@"!"];
if (range.location != NSNotFound) {
    /* This means the character has been found.
       The position is at range.location. */
}

Редактирование #2: вот способ измерить время выполнения.

#include <time.h>
...
clock_t start = clock(), end;
...[do your tasks]...
end = clock();
end = ((double)end - start) / CLOCKS_PER_SEC;
printf("Time taken: %f\n", end);
Другие вопросы по тегам