一、原由
前一段时间用php实现通讯录系统,需要用到拼音查找汉字功能,匹配通讯录的姓名字段,于是在网上搜索已有的开源代码,下面总结和分析一下思路和具体实现。
二、思路
查找了网上的多种解决方案,大致分为几类:
1.用javascript实现前端实拼音模糊搜索汉字,核心算法有以下2种:
列举所有字符:
http://www.cnblogs.com/meteoric_cry/p/5954547.html
也有用ASCII字节码字典来实现字符拼音检索:
http://www.jb51.net/article/100864.htm
2.用数据库函数来实现拼音模糊搜索汉字:
SQL Server:
http://blog.csdn.net/lisky119/article/details/8662673
Mysql:
http://www.cnblogs.com/zenghansen/p/4846460.html
3.后端语言逻辑实现拼音模糊搜索汉字:
java:
http://blog.csdn.net/zhangfuning1986/article/details/7738875
c#:
http://blog.csdn.net/lucky51222/article/details/21068235
4.用 excel 提前将汉字转换成拼音:
http://jingyan.baidu.com/article/48b37f8d39a69c1a646488df.html
三、实现
实际实现中,首先基于现场电脑比较老旧,且浏览器都是老版本,在前端用js实现拼音模糊搜索汉字可能会导致用户系统卡顿的问题,否定了方案1 ; 考虑语言和数据库因素,(php实现后台,mysql数据库) 优先考虑2.2 和4 ; 于是用方案4做了测试,发现实际使用当中,基于ASCII码字典实现的拼音检索汉字功能,有多音字查找的问题,写固定在程序逻辑里之后,后期没办法修正; 因此,采用方案4,再进行拼音修正是一个比较好的方法。
于是就按照方案4的教程,使用MS的EXCEL宏编程功能,复制VBA代码,制作数字签名,然后使用函数进行操作。如教程中所说,有部分汉字识别不出来,就只能手动改了,也算是一个折衷的办法。后来还用拼音检索字段来保存英文名,后期拼音由于多音字识别错误的,可以修正,也还不错。
然后就前端提醒用户使用空格分割多个关键字,后台逻辑用 “%” 做字符串拼接,搜索。