项目里面需要用到一个判断, 判断字符串的第一个字符是否是中文或者字母开头,这里找到了解决办法,记录一下。判断是否是汉字开头的方法,也可以用来判断textField在文本输入的时候的所占字节数,比用textfiled.length判断要准确多了。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
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;
}
|