iOS

判断传入的字符串是否以中文开头或结尾

2018-10-31  本文已影响0人  三浦蒼介

#pragma mark - 是否以中文开头

-(BOOL)isChineseFirst:(NSString*)firstStr

{

    //是否以中文开头(unicode中文编码范围是0x4e00~0x9fa5)

    intutfCode =0;

    void*buffer = &utfCode;

    NSRange range = NSMakeRange(0, 1);

    //判断是不是中文开头的,buffer->获取字符的字节数据 maxLength->buffer的最大长度 usedLength->实际写入的长度,不需要的话可以传递NULL encoding->字符编码常数,不同编码方式转换后的字节长是不一样的,这里我用了UTF16 Little-Endian,maxLength为2字节,如果使用Unicode,则需要4字节 options->编码转换的选项,有两个值,分别是NSStringEncodingConversionAllowLossy和NSStringEncodingConversionExternalRepresentation range->获取的字符串中的字符范围,这里设置的第一个字符 remainingRange->建议获取的范围,可以传递NULL

    BOOL b = [firstStr getBytes:buffer maxLength:2 usedLength:NULL encoding:NSUTF16LittleEndianStringEncoding options:NSStringEncodingConversionExternalRepresentation range:range remainingRange:NULL];

    if(b && (utfCode >=0x4e00&& utfCode <=0x9fa5))

        returnYES;

    else

        returnNO;

}

#pragma mark - 是否以中文结尾

-(BOOL)isChineseLast:(NSString*)lastStr {

    //是否以中文开头(unicode中文编码范围是0x4e00~0x9fa5)

    intutfCode =0;

    void*buffer = &utfCode;

    NSRangerange =NSMakeRange(lastStr.length-1,1);

    //判断是不是中文开头的,buffer->获取字符的字节数据 maxLength->buffer的最大长度 usedLength->实际写入的长度,不需要的话可以传递NULL encoding->字符编码常数,不同编码方式转换后的字节长是不一样的,这里我用了UTF16 Little-Endian,maxLength为2字节,如果使用Unicode,则需要4字节 options->编码转换的选项,有两个值,分别是NSStringEncodingConversionAllowLossy和NSStringEncodingConversionExternalRepresentation range->获取的字符串中的字符范围,这里设置的第一个字符 remainingRange->建议获取的范围,可以传递NULL

    BOOL b = [lastStr getBytes:buffer maxLength:2 usedLength:NULL encoding:NSUTF16LittleEndianStringEncoding options:NSStringEncodingConversionExternalRepresentation range:range remainingRange:NULL];

    if(b && (utfCode >=0x4e00&& utfCode <=0x9fa5))

        returnYES;

    else

        returnNO;

}

上一篇下一篇

猜你喜欢

热点阅读