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

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

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

发布了14 篇原创文章 · 获赞 8 · 访问量 9万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 技术黑板 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览