NSScanner для разбора файла

Я пытаюсь использовать NSScanner для анализа файла ics (который для анализа был преобразован в текстовый файл), т. Е.: календарь file.txt

вот формат текстового файла:

BEGIN:VEVENT  
DTSTAMP:20101129T061152Z  
UID:101139897313172011030314:00  
SUMMARY:14:00 - SYSI30251 - CB100 - SEM B  
DESCRIPTION:14:00 - 15:00, SYSI30251 - Module Name<br />Group: B <b>Seminar with Lecturer in room(s) (Clif) Computing Bldg 100  
DTSTART;TZID=Europe/London:20110303T140000  
DTEND;TZID=Europe/London:20110303T150000  
SEQUENCE:2  
END:VEVENT  
BEGIN:VEVENT  
DTSTAMP:20101129T061152Z  
UID:1011558905160182011030315:00  
SUMMARY:15:00 - COMP30251 - CFL015 - LEC    
DESCRIPTION:15:00 - 16:00, COMP30251 - Project Management<br /> Lecture with Lecturer in room(s) (Clif) Centre For Learning 015  
DTSTART;TZID=Europe/London:20110303T150000  
DTEND;TZID=Europe/London:20110303T160000  
SEQUENCE:2  
END:VEVENT  

Выше приведен формат файла. Ниже мой код:

NSString *path = [[NSBundle mainBundle] pathForResource:@"180946_icalfile" ofType:@"txt"];
    NSString *fileComponents = [[NSString alloc] initWithContentsOfFile:path encoding:NSUTF8StringEncoding error:nil];
    NSArray *lines = [fileComponents componentsSeparatedByString:@"\n"];


    NSEnumerator *nse = [lines objectEnumerator];
    NSString *mod;
    while(fileComponents = [nse nextObject]) {
        NSString *stringBetweenBrackets = nil;
        NSScanner *scanner = [NSScanner scannerWithString:fileComponents];
        [scanner scanUpToString:@"," intoString:nil];
        [scanner scanString:@"" intoString:nil];
        [scanner scanUpToString:@"DTSTART" intoString:&stringBetweenBrackets];

        NSLog(@"%@", stringBetweenBrackets);

По сути, я хочу сохранить все "ОПИСАНИЯ" и сохранить их как переменные или как часть массива. В настоящее время код выводит описания на консоль, и я хотел бы сохранить их как переменные. Может ли кто-нибудь показать мне, как это можно сделать?

2 ответа

Я не уверен, что это именно то, что вы хотите, однако http://parsekit.com/ может упростить вашу работу. Это превратит исходный код в массив токенов. И вы можете выполнять итерацию каждого токена, чтобы отфильтровать токен "ОПИСАНИЕ" и собрать следующие токены для обработки.

Попробуйте использовать следующее регулярное выражение вместо использования NSScanner:

/DESCRIPTION:([^\n]+)\n/is
Другие вопросы по тегам