2016-03-26 10 views
1

Ich versuche, Textdatei und Gruppeninformationen vor und nach einem ":" zu analysieren, so dass ich dann wissen kann, was sich auf was bezieht.Objc Regex - Parse String mit Gruppen

Ich verwende die folgenden

//NSString *pattern = @"\\[(.*?)\\]"; //[] 
//NSString *pattern = @"(\\w+:)"; //word: 
NSString *pattern [email protected]"(\\w+:)\\[(.*?)\\]"; 
NSRegularExpression *regex = [NSRegularExpression regularExpressionWithPattern:pattern options:NSRegularExpressionCaseInsensitive error:nil]; 
NSString *input = contents; //contents being the value taken from the text file 

NSMutableArray *matches = [NSMutableArray arrayWithCapacity:[myArray count]]; 
for (NSTextCheckingResult *match in myArray) { 
    //NSUInteger numberOfRanges = [match numberOfRanges]; 
    //NSLog(@"%lu", (unsigned long)numberOfRanges); 
    NSRange matchRange = [match rangeAtIndex:1]; 
    [matches addObject:[input substringWithRange:matchRange]]; 
    NSLog(@"%@", [matches lastObject]); 
} 

Die „[]“ Werke und das „Wort:“ funktioniert, aber wenn ich ihnen, dass ich nichts miteinander zu verbinden zurück.

Brackets (Ausgang)

2016-03-26 09:20:36.302 LevelBuilder[14658:550234] 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1 
... 
2016-03-26 09:20:36.304 LevelBuilder[14658:550234] 17,1 

Wort (Ausgang)

2016-03-26 09:18:18.189 LevelBuilder[14464:543898] tiles: 
2016-03-26 09:18:18.189 LevelBuilder[14464:543898] boxes: 
2016-03-26 09:18:18.189 LevelBuilder[14464:543898] goals: 
2016-03-26 09:18:18.189 LevelBuilder[14464:543898] start: 

Was bin ich in das Muster fehlt

NSString *pattern [email protected]"(\\w+:)\\[(.*?)\\]"; 

Die Daten ist ein Beispiel

tiles: 
    [ 
     [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1] 
     ,[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,1] 
     ,[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,1] 
     ,[0,0,0,0,0,1,1,1,1,1,1,1,1,1,0,1,0,0,1] 
     ,[1,1,1,1,1,1,0,0,0,0,0,0,0,1,1,1,0,0,1] 
     ,[1,0,0,0,0,0,0,1,1,1,0,0,0,0,0,0,0,0,1] 
     ,[1,0,0,0,0,0,0,1,1,1,0,0,1,1,1,0,0,0,1] 
     ,[1,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,1] 
     ,[1,0,0,1,1,1,1,1,1,1,1,1,1,0,1,0,0,0,1] 
     ,[1,0,0,0,1,0,0,0,0,0,0,0,0,0,1,1,1,1,1] 
     ,[1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0] 
     ,[1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0] 
     ,[1,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0] 
    ], 
    boxes: [ 
      [5,6],[6,5],[10,5],[11,5],[16,4],[16,5],[16,6],[16,7] 
      ], 
    goals: [ 
      [1,8],[1,9],[1,10],[1,11],[2,10],[2,11],[3,10],[3,11] 
      ], 
    start: [17,1] 
+1

Es ist nicht ganz klar. Vielleicht brauchst du ['(? S) (\\ w +:) \\ s * \\ [. *? \\] (? =, \ R? \ N | $)'] (https://regex101.com/r/sT5oA9/1)? –

+0

Danke @ WiktorStribiżew das hat sie als 4 individuelle Übereinstimmungen –

+0

Bedeutet es, dass Sie nach dieser Lösung gesucht haben? –

Antwort

1

Da Sie benötigen jedes „Wort“ mit seinem entsprechenden [...] gefolgt übereinstimmen, können Sie einen RegexMuster mit 2 Capture-Gruppen und einen Look-Ahead verwenden, das wird „Temperament“ das faule Punktanpassungsmuster:

@"(?s)(\\w+):\\s*\\[(.*?)\\](?=,\r?\n\\s*\\w+:|$)" 

See die regex demo

das Muster passt:

  • (?s) - eine . ermöglichen eine neue Zeile entsprechen
  • (\w+): - Spiel und erfassen in Gruppe 1 ein oder mehr alphanumerischen Zeichen, und dann ein :
  • \s* entspricht - 0+ Leerzeichen Zeichen
  • \[(.*?)\] - entsprechen die [...] erfassen alle, was im Innern in Gruppe 1, wenn die letzten ]
  • (?=,\r?\n\s*\w+:|$) - wird gefolgt mit dem Ende der Zeichenfolge ($) oder ein Komma gefolgt von einem Zeilenumbruch gefolgt von 0+ Whitespacesymbol gefolgt von einem "Wort" gefolgt von :.