方法一:
- (BOOL)hasChinese:(NSString *)str { for(int i=0; i< [str length];i++){ int a = [str characterAtIndex:i]; if( a > 0x4e00 && a < 0x9fff) { return YES; } } return NO; }
方法二:
- (BOOL)isHasChineseWithStr:(NSString *)strFrom { for (int i=0; i<strFrom.length; i++) { NSRange range =NSMakeRange(i, 1); NSString * strFromSubStr=[strFrom substringWithRange:range]; const char *cStringFromstr = [strFromSubStr UTF8String]; if (strlen(cStringFromstr)==3) { //漢字 return YES; } else if (strlen(cStringFromstr)==1) { //字母 } } return NO; }
3.根據ASCII碼
for (int i = 0; i < text.Length; i++){ if ((int)text[i] > 127) { return YES; } else { return NO; } }
這兩種方法第一種是根據漢字的編碼位置判斷的,幾乎所有漢字的 UNICODE 編碼范圍是4e00-9fbb。在范圍內的就返回yes,可是因為區間范圍有多處,這里只判斷一處最大的范圍(幾萬字),其余幾個范圍少(一共才幾百字)。第二種是根據字節數判斷的。第三種是根據ASCII碼判斷的。在 ASCII碼表中,英文的范圍是0-127,而漢字則是大於127。