iOS判斷字符串中含不含有漢字


轉載請注明出處!!!

方法一:

- (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。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM