通过拼音模糊搜索汉字的功能实现

通过拼音模糊搜索汉字的功能实现_第1张图片

一、原由

前一段时间用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代码,制作数字签名,然后使用函数进行操作。如教程中所说,有部分汉字识别不出来,就只能手动改了,也算是一个折衷的办法。后来还用拼音检索字段来保存英文名,后期拼音由于多音字识别错误的,可以修正,也还不错。

然后就前端提醒用户使用空格分割多个关键字,后台逻辑用 "%" 做字符串拼接,搜索。

完美!

↓↓↓                (๑❛ᴗ❛๑)

你可能感兴趣的:(通过拼音模糊搜索汉字的功能实现)