NSString *titleStr = @"琳小兮"; //先截取字符串,拿到第一个字符        NSString *firstStr = [titleStr substringToIndex:1];                 //判断是不是中文开头的        BOOL isFirst = [self isChineseFirst:firstStr];        if (isFirst)           NSLog(@"第一个字符是中文开头的--%@", firstStr);        else        {            //判断是不是字母开头的            BOOL isA = [self MatchLetter:firstStr];            if (isA)                NSLog(@"第一个是字母开头的--%@", firstStr);            else                NSLog(@"--不是中文和字母开头的--%@",titleStr);                        } | 
| 
 1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
 | 
#pragma mark 正则表达式-(BOOL)MatchLetter:(NSString *)str{    //判断是否以字母开头    NSString *ZIMU = @"^[A-Za-z]+$";    NSPredicate *regextestA = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", ZIMU];         if ([regextestA evaluateWithObject:str] == YES)        return YES;    else        return NO;}-(BOOL)isChineseFirst:(NSString *)firstStr{    //是否以中文开头(unicode中文编码范围是0x4e00~0x9fa5)    int utfCode = 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))        return YES;    else        return NO;} | 
原文:http://www.cnblogs.com/shifu/p/5303012.html