1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > php 拼音搜索 通过拼音模糊搜索汉字的功能实现

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

时间:2023-12-12 09:03:56

相关推荐

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

一、原由

前一段时间用php实现通讯录系统,需要用到拼音查找汉字功能,匹配通讯录的姓名字段,于是在网上搜索已有的开源代码,下面总结和分析一下思路和具体实现。

二、思路

查找了网上的多种解决方案,大致分为几类:

1. 用javascript实现前端实拼音模糊搜索汉字,核心算法有以下2种:

列举所有字符:/meteoric_cry/p/5954547.html

也有用ASCII字节码字典来实现字符拼音检索:/article/100864.htm

2. 用数据库函数来实现拼音模糊搜索汉字:

SQL Server:/lisky119/article/details/8662673

Mysql:/zenghansen/p/4846460.html

3. 后端语言逻辑实现拼音模糊搜索汉字:

java:/zhangfuning1986/article/details/7738875

c#:/lucky51222/article/details/21068235

4. 用 excel 提前将汉字转换成拼音:/article/48b37f8d39a69c1a646488df.html

三、实现

实际实现中,首先基于现场电脑比较老旧,且浏览器都是老版本,在前端用js实现拼音模糊搜索汉字可能会导致用户系统卡顿的问题,否定了方案1 ; 考虑语言和数据库因素,(php实现后台,mysql数据库) 优先考虑2.2 和4 ; 于是用方案4做了测试,发现实际使用当中,基于ASCII码字典实现的拼音检索汉字功能,有多音字查找的问题,写固定在程序逻辑里之后,后期没办法修正; 因此,采用方案4,再进行拼音修正是一个比较好的方法。

于是就按照方案4的教程,使用MS的EXCEL宏编程功能,复制VBA代码,制作数字签名,然后使用函数进行操作。如教程中所说,有部分汉字识别不出来,就只能手动改了,也算是一个折衷的办法。后来还用拼音检索字段来保存英文名,后期拼音由于多音字识别错误的,可以修正,也还不错。

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

完美!

↓↓↓ (๑❛ᴗ❛๑)

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。