细心的网友可能会发现,VeryCD的资源搜索是支持拼音的,不论你是直接输入拼音,还是输入同音字,我们的搜索程序都会提示你正确的关键字。比如: http://search.verycd.com/search?q=萧雅轩
之前我们使用的是一个网上已经很普遍的汉字转拼音函数,通过使用后发现,这个函数的算法虽然简便,但只能取得GB2312中根据拼音排列的3755个常用汉字,所以其适用范围很有限。由于其它汉字大都按部首/笔画顺序排列,所以我们只能通过建立一个汉字-拼音表来实现一一对应。
这个时候输入法生成器就派上了用场,利用它的逆转换功能生成一个汉字拼音的文本文件。然后再写了一个PHP小程序删除了这个文本文件中的词组和多音字。
CODE
<?
//注意,在2000/XP下生成的文本文件是Unicode格式,需要先转换到GB
$py = file_get_contents("WINPY.TXT");
$arr_tmp = explode("\r\n", $py);
$arr_py = array();
foreach ($arr_tmp as $v)
{
? ?if (preg_match("/^[".chr(0×81)."-".chr(0xfe)."].[a-z]/", $v))
? ?{
? ? ? ?$word = substr($v, 0, 2);
? ? ? ?if (!$arr_py[$word])
? ? ? ?{
? ? ? ? ? ?$arr_py[$word] = substr($v, 2);
? ? ? ? ? ?$output .= $v."\n";
? ? ? ?}
? ?}
}
$handle = fopen("WINPY2.TXT", ‘w’);
fwrite($handle, $output);
?>
//注意,在2000/XP下生成的文本文件是Unicode格式,需要先转换到GB
$py = file_get_contents("WINPY.TXT");
$arr_tmp = explode("\r\n", $py);
$arr_py = array();
foreach ($arr_tmp as $v)
{
? ?if (preg_match("/^[".chr(0×81)."-".chr(0xfe)."].[a-z]/", $v))
? ?{
? ? ? ?$word = substr($v, 0, 2);
? ? ? ?if (!$arr_py[$word])
? ? ? ?{
? ? ? ? ? ?$arr_py[$word] = substr($v, 2);
? ? ? ? ? ?$output .= $v."\n";
? ? ? ?}
? ?}
}
$handle = fopen("WINPY2.TXT", ‘w’);
fwrite($handle, $output);
?>
以下压缩包中就是原始的WINPY.TXT和经过处理后的WINPY2.TXT
通过读入WINPY2.TXT再配合几个字符串操作函数就可以非常简单的获取到汉字的拼音了(具体的代码xdanger还在写,我这里就不贴出来了)
附注:我们在最后处理的时候忽略了多音字的因素,以后仍然有待改进。
网上关于正则判断中文的文章大都使用[chr(0xa1)-chr(0xff)]来判断中文,事实上这只能判断出GB2312的几千个汉字,生僻字和繁体字都不包含在内,正确的应该是[chr(0x81)-chr(0xfe)]
WINPY.rar