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

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值