國(guó)內(nèi)最大的酷站演示中心!
今天在yyf9989 的 blog 上看到一篇《c#計(jì)算漢語(yǔ)拼音碼 》,看了里面的代碼,覺(jué)得是比較繁瑣。它主要是檢索輸入的漢字在數(shù)組中的位置,然后返回第一個(gè)字母。于是就想起來(lái)了,可以利用漢字在計(jì)算機(jī)里面的編碼來(lái)的到漢字的首拼音,查找了一些資料,通過(guò)以下的方法成功的得到了解決。就放在這里,請(qǐng)朋友們參考。
static public string getchinesespell(string strtext)
{
int len = strtext.length;
string mystr = "";
for(int i=0;i<len;i++)
{
mystr += getspell(strtext.substring(i,1));
}
return mystr;
}
static public string getspell(string cnchar)
{
byte[] arrcn = encoding.default.getbytes(cnchar);
if(arrcn.length > 1)
{
int area = (short)arrcn[0];
int pos = (short)arrcn[1];
int code = (area<<8) + pos;
int[] areacode = {45217,45253,45761,46318,46826,47010,47297,47614,48119,48119,49062,49324,49896,50371,50614,50622,50906,51387,51446,52218,52698,52698,52698,52980,53689,54481};
for(int i=0;i<26;i++)
{
int max = 55290;
if(i != 25) max = areacode[i+1];
if(areacode[i]<=code && code<max)
{
return encoding.default.getstring(new byte[]{(byte)(65+i)});
}
}
return "*";
}
else return cnchar;
}