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