2016-03-26 5 views
1

J'essaie d'analyser les fichiers texte et les informations de groupe avant et après un ":" afin que je puisse alors savoir ce qui concerne quoi.Objc Regex - Analyser une chaîne avec des groupes

J'utilise les

//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]); 
} 

suivant les « [] » œuvres et le « mot: » œuvres, mais quand je les rejoins ensemble, je reçoivent rien en retour.

supports (sortie)

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 

Word (sortie)

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: 

Qu'est-ce que je manque dans le modèle

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

Les données sont un exemple

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

Ce n'est pas très clair. Peut-être avez-vous besoin de ['(? S) (\\ w +:) \\ s * \\ [. *? \\] (? =, \ R? \ N | $)'] (https://regex101.com/r/sT5oA9/1)? –

+0

Merci @ WiktorStribiżew qui les a comme 4 correspondances individuelles –

+0

Cela signifie-t-il que vous étiez à la recherche de cette solution? –

Répondre

1

Puisque vous avez besoin de faire correspondre chaque « mot » suivi avec son correspondant [...], vous pouvez utiliser un motif regex contenant 2 groupes de capture et un préanalyse qui « tempérer » le modèle correspondant de points paresseux:

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

Voir le regex demo

le motif correspond:

  • (?s) - permettent un . pour correspondre à une nouvelle ligne
  • (\w+): - Match et la capture dans le Groupe 1 un ou plusieurs caractères alphanumériques, puis correspondent à une :
  • \s* - 0+ caractères blancs
  • \[(.*?)\] - correspondre à la [...] Enregistrant tous ce qui est à l'intérieur dans le groupe 1 si le dernier ]
  • (?=,\r?\n\s*\w+:|$) - est suivi de la fin de la chaîne ($) ou d'une virgule suivie d'un saut de ligne suivi de 0+ symboles d'espaces suivis d'un "mot" suivi de :.