ios專案中會用到對通訊錄的聯絡人或是會員按姓名為關鍵字排序,因為nsarray並不直接支援對漢字的排序,這就要通過將漢字轉換成拼音完成按a~z的排序,這看起來是個頭疼的問題,因為牽扯到漢字轉為拼音,kmyhy給出乙個較易實現的方法,獲取漢字的首字的首字母,如將「王」變成「w」,完整文章(傳送門)。
其中他通過pinyinfirstletter函式獲取中文拼音,函式原理是:「pinyinfirstletter基於這麼乙個簡單的原理:我們知道,在objective c語言中,字串是以unicode進行編碼的。在unicode字符集中,漢字的編碼範圍為4e00 到 9fa5 之間(即從第19968開始的20902個字元是中文簡體字符)。我們把這些字元的拼音首字母按照順序都存放在乙個char陣列中。當我們查詢乙個漢字的拼音首字母時,只需把這個漢字的unicode碼(即char強制轉換為int)減去19968,然後用這個數字作為索引去找char陣列中存放的字母即可。」函式**我也貼了過來。
[cpp]view plain
copy
print?
char
pinyinfirstletter(unsignedshort hanzi)
else
} 這個方法真是用很原理的東西,解決乙個巧妙問題,但也存在乙個問題:不支援漢字(首字)的第二個字母的排序,據說對映的char陣列會很大。這裡我給出我的方法,先在cocoatouch框架上看看有什麼能用到的,在nsstring有乙個函式localizedcompare:,它的功能是通過自身與給定字串的比較,返回乙個本地化的比較結果,也就是說這個函式是支援漢字比較的。
進一步localizedcompare:只是字串與字串的比較,我們要讓nsarray陣列通過按關鍵字為漢字字串排序,我們繼續在nsarray的sdk上下功夫,我們發現除了sortdarrayusingdescriptors:通過nssortdescriptor排序;還有sotedarrayusingfunction:context:,這個函式支援我們自定義乙個函式制定比較規則,返回比較結果,這樣問題一下便解決了。我先把**貼出來。
[cpp]view plain
copy
print?
nsinteger nicknamesort(id user1, id user2,
void
*context)
{ user *u1,*u2;
//型別轉換
u1 = (user*)user1;
u2 = (user*)user2;
return
[u1.nickname localizedcompare:u2.nickname
];
}
在需要比較地方,呼叫比較函式
[cpp]view plain
copy
print?
sortarr = [arr sortedarrayusingfunction:nicknamesort context:null];
需要的**很少吧,這樣做會有幾方面的好處:1 支援多個漢字按字母序排序(若第乙個字的第乙個字母相同,則按第乙個字的第二個字母比較,若第乙個字的字母完全相同,按第二個字的首字母繼續排序)。 2 原本可能需要儲存漢字拼音的地方,現在不需要了。 3 可以通過對nicknamesortde進一步定製,完成更複雜的比較,比如先比較會員狀態,在按姓名字母序完成比較。4 整體結構簡單 使用的都是cocatouch框架下的的方法。
再感嘆一句,cocatouch你真厲害!!
IOS陣列按中文關鍵字以字母序排序
ios專案中會用到對通訊錄的聯絡人或是會員按姓名為關鍵字排序,因為nsarray並不直接支援對漢字的排序,這就要通過將漢字轉換成拼音完成按a z的排序,這看起來是個頭疼的問題,因為牽扯到漢字轉為拼音,kmyhy給出乙個較易實現的方法,獲取漢字的首字的首字母,如將 王 變成 w 完整文章 傳送門 其中...
關鍵字 php提取關鍵字中文分詞
每日17點準時技術乾貨分享 需求 做seo的keywords時,需要從標題或者正文裡提取關鍵字 2.封裝 loaddict pa setsource content pa startanalysis true tags pa getfinallykeywords num 獲取文章中的n個關鍵字 re...
IOS 屬性關鍵字
ios 5之後便支援arc了,在arc的情況下物件引用分為 strong強引用 乙個物件如果有乙個及以上的強引用指向它,那麼他將不會釋放 weak弱引用 乙個物件如果只有弱應用指向它,那麼它將被釋放掉 注 兩個物件若相互保留對方的強引用,那麼會照成記憶體洩漏。其他 copy 物件的複製,複製之後得到...