- 相關推薦
PHP漢字轉換為拼音字頭原理
學習猶如逆水行舟,不進則退。下面是小編整理的PHP漢字轉換為拼音字頭原理,希望對大家學習PHP有用,更多消息請關注應屆畢業生網。
GB 2312中對所收漢字進行了“分區”處理,每區含有94個漢字/符號。這種表示方式也稱為區位碼。
1)01-09區為特殊符號。
2)16-55區為一級漢字,按拼音排序。
3)56-87區為二級漢字,按部首/筆畫排序。
4)10-15區及88-94區則未有編碼。
在使用GB2312的程序中,通常采用EUC儲存方法,以便兼容于ASCII。瀏覽器編碼表上的“GB2312”,通常都是指“EUC-CN”表示法。
每個漢字及符號以兩個字節來表示。第一個字節稱為“高位字節”(也稱“區字節)”,第二個字節稱為“低位字節”(也稱“位字節”)。
“高位字節”使用了0xA1-0xF7(把01-87區的區號加上0xA0),“低位字節”使用了0xA1-0xFE(把01-94加上 0xA0)。由于一級漢字從16區起始,漢字區的“高位字節”的范圍是0xB0-0xF7,“低位字節”的范圍是0xA1-0xFE,占用的碼位是 72*94=6768。其中有5個空位是D7FA-D7FE。
例如“啊”字在大多數程序中,會以兩個字節,0xB0(第一個字節) 0xA1(第二個字節)儲存。區位碼=區字節+位字節(與區位碼對比:0xB0=0xA0+16,0xA1=0xA0+1)。
設計:
用一個數組存放國標一級漢字不同讀音的起始區位碼 :如
static final int[] secPosValueList = {
1601, 1637, 1833, 2078, 2274, 2302, 2433, 2594, 2787, 3106, 3212, 3472,
3635, 3722, 3730, 3858, 4027, 4086, 4390, 4558, 4684, 4925, 5249, 9999};
一個數據存放存放國標一級漢字不同讀音的起始區位碼對應讀音
static final char[] firstLetter = {
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'j', 'k', 'l', 'm', 'n', 'o', 'p',
'q', 'r', 's', 't', 'w', 'x', 'y', 'z'};
處理方法:
1. 判斷是否為英文之母
2. 如果是,直接返回英文之母
3. 取字符的編碼值
4. 比較判斷其編碼值在碼表中的位置。
5. 根據位置值,返回之母表中相應值
更多PHP相關文章推薦:
【PHP漢字轉換為拼音字頭原理】相關文章:
PHP學習:PHP拼音類01-25
PHP簡單的分頁過程與原理03-30
PHP底層的運行機制與原理06-20
php字符轉URL地址的函數06-12
分析php日期轉時間戳06-11
php漢字正則表達式06-03
如何解析php日期轉時間戳07-08
Excel2010怎么給漢字標注拼音03-14