2012-11-23 55 views

回答

4

使用NSString componentsSeparatedByString:拆分串起来。首先使用@"^"。该名称将位于索引2处。然后使用@";"将索引3中的子字符串拆分。索引1处的字符串将为您提供您想要的第二部分。

NSArray *substrings = [string componentsSeparatedByString:@"^"]; 
NSString *name = substrings[2]; 
name = [name stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceCharacterSet]]; 
NSString *lastpart = substrings[3]; 
NSArray *moresubstrings = [lastpart componentsSeparatedByString:@";"]; 
NSString *secondPiece = moresubstrings[1]; 
0

没有在这里更多的细节是蛮力方式:

NSString* string = @"%B999999^PDVS123456789012^PADILLA L.     ^0X0000399   ?*;999999554749123456789012=00X990300000?*"; 
NSRange nameRange = {26, 10}; 
NSString *name = [string substringWithRange:nameRange]; 
NSRange numRange = {80, 39}; 
NSString *num = [string substringWithRange:numRange]; 

的文档是你的朋友:NSString Class Reference

+0

请记住,此解决方案仅在数据保证为固定长度时才有效。 – rmaddy

+0

是的。究竟。我的意思是我很欣赏你的答案,但硬编码范围不是很明智。但是,谢谢你的回答。 :) – jongbanaag

0

不知道确切的输入模式是什么(我们有你的正的-1的例子),它很难准确地说出你如何正确解析它;但NSRegularExpression提供你所需要的(除了其他建议的途径):

#import <Foundation/Foundation.h> 

int main(int argc, char *argv[]) { 
    @autoreleasepool { 
     NSString *sampleText = @"%B999999^PDVS123456789012^PADILLA L.     ^0X0000399   ?*;999999554749123456789012=00X990300000?*"; 
     NSError *regexError = nil; 
     NSRegularExpressionOptions options = 0; 
     NSString *pattern = @"^%\\w+\\^\\w+\\^([A-Za-z\\s]+\\.).+\\?\\*\\;(.+)\\?\\*$"; 
     NSRegularExpression *expression = [NSRegularExpression regularExpressionWithPattern:pattern options:options error:&regexError]; 

     NSTextCheckingResult *match = [expression firstMatchInString:sampleText options:0 range:range]; 
     if(match) { 
      NSRange nameRange = [match rangeAtIndex:1]; 
      NSRange numberRange = [match rangeAtIndex:2]; 

      printf("name = %s ",[[sampleText substringWithRange:nameRange] UTF8String]); 
      printf("number = %s\n",[[sampleText substringWithRange:numberRange] UTF8String]); 
     } 
    } 
} 

这一点粉底应用程序打印以下控制台:

name = PADILLA L. number = 999999554749123456789012=00X990300000 

用于分析输入字符串的正则表达式可能需要根据输入字符串的变化来调整。现在它是(未转义的):

^%\w+\^\w+\^([A-Za-z\s]+\.).+\?\*\;(.+)\?\*$