NSScanner

NSScanner : NSObject

函数、方法、属性

/** 获取被扫描的字符串 */
@property (readonly, copy) NSString *string;
/** 扫描的位置 */
@property NSUInteger scanLocation;
/** 需要忽略的字符 */
@property (nullable, copy) NSCharacterSet *charactersToBeSkipped;
/** 是否区分大小写 */
@property BOOL caseSensitive;
/** ?? */
@property (nullable, retain) id locale;
/**
 初始化Scanner对象
 @param string 要进行扫描的词
 @return Scanner
 */
- (instancetype)initWithString:(NSString *)string NS_DESIGNATED_INITIALIZER;

使用

NSString * result = nil;
NSScanner * scanner = [[NSScanner alloc] initWithString:@"123abc~!@챠처쳐초쵸"];
int value;
scanner.charactersToBeSkipped = [NSCharacterSet characterSetWithCharactersInString:@"a"];
scanner.scanLocation = 0;
while (![scanner isAtEnd]) {
    // 扫描到的字符是整型
    if ([scanner scanInt:&value]) {
        NSLog(@"%d, %lu",value,(unsigned long)scanner.scanLocation);
        continue;
    }
    // 扫描到ab字符
    else if ([scanner scanString:@"ab" intoString:&result]) {
        NSLog(@"%@, %lu", result, (unsigned long)scanner.scanLocation);
        continue;
    }
    // 其他情况让扫描的位置向前一一位
    else {
        scanner.scanLocation++;
    }
}

NSScanner (NSExtendedScanner)

/**
 扫描Int
 @param result 使用Int接收扫描到的字符串
 @return 是否扫描到
 */
- (BOOL)scanInt:(nullable int *)result;
/**
 扫描NSInteger
 @param result 使用NSInteger接收扫描到的字符串
 @return 是否扫描到
 */
- (BOOL)scanInteger:(nullable NSInteger *)result;
/**
 扫描long long
 @param result 使用long long接收扫描到的字符串
 @return 是否扫描到
 */
- (BOOL)scanLongLong:(nullable long long *)result;
/**
 扫描unsigned long long
 @param result 使用unsigned long long接收扫描到的字符串
 @return 是否扫描到
 */
- (BOOL)scanUnsignedLongLong:(nullable unsigned long long *)result;
/**
 扫描float
 @param result 使用float接收扫描到的字符串
 @return 是否扫描到
 */
- (BOOL)scanFloat:(nullable float *)result;
/**
 扫描double
 @param result 使用double接收扫描到的字符串
 @return 是否扫描到
 */
- (BOOL)scanDouble:(nullable double *)result;
/**
 扫描十六进制(可选以“0x”或“0x”为前缀)
 @param result 使用unsigned接收扫描到的字符串转换为十进制
 @return 是否扫描到
 */
- (BOOL)scanHexInt:(nullable unsigned *)result;
/**
 扫描十六进制(可选以“0x”或“0x”为前缀)
 @param result 使用unsigned long long接收扫描到的字符串转换为十进制
 @return 是否扫描到
 */
- (BOOL)scanHexLongLong:(nullable unsigned long long *)result;
/**
 扫描十六进制(对应于%a或%A格式。需要“0x”或“0x”前缀)
 @param result 使用float接收扫描到的字符串转换为十进制
 @return 是否扫描到
 */
- (BOOL)scanHexFloat:(nullable float *)result;
/**
 扫描十六进制(对应于%a或%a格式。需要“0x”或“0x”前缀)
 @param result 使用double接收扫描到的字符串转换为十进制
 @return 是否扫描到
 */
- (BOOL)scanHexDouble:(nullable double *)result;
/**
 扫描字符串(对应于%a或%a格式。需要“0x”或“0x”前缀)
 @param result 使用double接收扫描到的字符串转换为十进制
 @return 是否扫描到
 */
/**
 扫描字符串
 @param string 要扫描的字符串
 @param result 扫描到的字符串
 @return 是否扫描到
 */
- (BOOL)scanString:(NSString *)string
        intoString:(NSString * _Nullable * _Nullable)result;
/**
 扫描字符串
 @param set 要扫描的C字符
 @param result 扫描到的字符串
 @return 是否扫描到
 */
- (BOOL)scanCharactersFromSet:(NSCharacterSet *)set
                   intoString:(NSString * _Nullable * _Nullable)result;
/**
 扫描字符串
 @param string 要扫描的字符串
 @param result 扫描到的字符串和它前面的字符串
               但是如果前面有部分字符串被其他扫描方式扫描过,则不会保留被扫描的部分
 @return 是否扫描到
 */
- (BOOL)scanUpToString:(NSString *)string
            intoString:(NSString * _Nullable * _Nullable)result;
/**
 扫描字符串
 @param string 要扫描的C字符
 @param result 扫描到的字符串和它前面的字符串
               但是如果前面有部分字符串被其他扫描方式扫描过,则不会保留被扫描的部分
 @return 是否扫描到
 */
- (BOOL)scanUpToCharactersFromSet:(NSCharacterSet *)set
                       intoString:(NSString * _Nullable * _Nullable)result;
/** 是否扫描完毕 */
@property (getter=isAtEnd, readonly) BOOL atEnd;
/** 便利构造 */
+ (instancetype)scannerWithString:(NSString *)string;
+ (id)localizedScannerWithString:(NSString *)string;
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
非常抱歉,我的回答不够准确,我理解为每个逗号都是正常的分隔符。对于你提出的情况,CSV 文件中的每行可能包含带有逗号的字段,这时候需要使用特殊的方法来处理这些字段。通常的做法是在包含逗号的字段两侧加上引号,表示该字段是一个整体。 下面是一个可以处理带有逗号的字段的示例代码,该代码使用 NSString 的 `stringByTrimmingCharactersInSet:` 方法来去除字段两侧的引号,使用 `stringByReplacingOccurrencesOfString:withString:` 方法将两侧的双引号替换为单引号,最后使用 `componentsSeparatedByString:` 方法将一行数据按逗号分割成一个数组: ```objc NSString *csv = @"name,age,email\nJohn,25,\"john@example.com, USA\"\nJane,30,jane@example.com"; NSArray *lines = [csv componentsSeparatedByString:@"\n"]; NSString *firstLine = [lines firstObject]; NSArray *fields = [firstLine componentsSeparatedByString:@","]; NSString *secondField = [fields objectAtIndex:1]; NSString *thirdField = [fields objectAtIndex:2]; for (NSInteger i = 1; i < [lines count]; i++) { NSString *line = [lines objectAtIndex:i]; NSArray *values = [self parseCSVLine:line]; NSLog(@"%@", [values objectAtIndex:2]); // 输出:john@example.com, USA } // 解析带有逗号的 CSV 行 - (NSArray *)parseCSVLine:(NSString *)line { NSMutableArray *values = [NSMutableArray array]; NSScanner *scanner = [NSScanner scannerWithString:line]; scanner.charactersToBeSkipped = nil; NSString *field = nil; while (![scanner isAtEnd]) { if ([scanner scanString:@"\"" intoString:NULL]) { [scanner scanUpToString:@"\"" intoString:&field]; [scanner scanString:@"\"" intoString:NULL]; field = [field stringByTrimmingCharactersInSet:[NSCharacterSet characterSetWithCharactersInString:@"\""]]; field = [field stringByReplacingOccurrencesOfString:@"\"" withString:@"'"]; } else { [scanner scanUpToString:@"," intoString:&field]; } [values addObject:field]; if (![scanner isAtEnd]) { [scanner scanString:@"," intoString:NULL]; } } return values; } ``` 在上面的代码中,首先使用 `componentsSeparatedByString:` 方法将 CSV 文件按行分割,然后获取第一行的内容。接着使用 `componentsSeparatedByString:` 方法将第一行按逗号分割,获取第二个和第三个字段的内容。然后遍历 CSV 文件中的每一行数据,使用 `parseCSVLine:` 方法将一行数据解析成一个数组。在 `parseCSVLine:` 方法中,首先使用 NSScanner 类来扫描一行数据,如果遇到双引号,则表示该字段包含逗号,需要特殊处理。如果没有遇到双引号,则直接使用逗号进行分割。最后将每个字段添加到一个 NSMutableArray 中,并返回该数组作为结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值