语音指令怎么避免同音词干扰?

说在前面

最近实现了一个b站语音助手插件,可以通过语音来控制播放页面上指定的视频,在语音识别的过程中遇到了一个问题:语音识别出来的文本是预设语音指令同音词,导致语音指令匹配不上。这个时候有两种解决方案:

  • 1.换个指令
  • 2.直接按拼音来匹配指令

对插件感兴趣的同学可以看下这篇文章:因为懒得点鼠标,我给B站做了个语音助手

引入拼音转换库

这里我选择了 githubshar 最多的一个库:pinyin


该库具备:

  • 根据词组智能匹配最正确的拼音。
  • 支持多音字。
  • 简单的繁体支持。
  • 支持多种不同拼音风格。

vue项目中引入

Vue 项目里,我们可以直接通过 npm 工具来引入拼音转换库:

css 复制代码
npm install pinyin --save

引入完成后即可直接使用:

javascript 复制代码
import pinyin from "pinyin";

console.log(pinyin("中心"));    // [ [ 'zhōng' ], [ 'xīn' ] ]

插件中引入

在插件中我们可以直接将js文件复制到项目中来引入使用。

首先,通过npm install pinyin获取拼音转换库的相关文件。在安装完成后的项目目录中,找到 pinyin 包的 dist 文件夹,其中的 index.js 文件便是我们需要的核心代码。将这个 index.js 文件复制一份,粘贴到自己的插件项目中,即可完成库的引入。

指令匹配

比如现在我们有个指令名字为:下拉 ,但是语音识别出来的文本是 下啦,这样的话就无法将语言和指令匹配上。

arduino 复制代码
const cmd= "下拉";
const text = "下啦";
console.log(text.includes(cmd)) //false

这时候我们就可以将他们都转为拼音再进行匹配。

arduino 复制代码
const { pinyin } = window.pinyinPro;
const cmd= "下拉";
const text = "下啦";
console.log(text.includes(cmd)) //false
const cmdPinyin = pinyin(cmd);
console.log(cmdPinyin); //xià lā
const textPinyin = pinyin(text);
console.log(textPinyin); //xià lā
console.log(textPinyin.includes(cmdPinyin)) //true

公众号

关注公众号『 前端也能这么有趣 』,获取更多有趣内容。

发送 加群 还可以加入群聊,一起来学习(摸鱼)吧~

说在后面

🎉 这里是 JYeontu,现在是一名前端工程师,有空会刷刷算法题,平时喜欢打羽毛球 🏸 ,平时也喜欢写些东西,既为自己记录 📋,也希望可以对大家有那么一丢丢的帮助,写的不好望多多谅解 🙇,写错的地方望指出,定会认真改进 😊,偶尔也会在自己的公众号『前端也能这么有趣』发一些比较有趣的文章,有兴趣的也可以关注下。在此谢谢大家的支持,我们下文再见 🙌。

相关推荐
CDwenhuohuo5 小时前
用spark-md5实现切片上传前端起node模拟上传文件大小,消耗时间
前端
阿桂有点桂5 小时前
React使用笔记(持续更新中)
前端·javascript·react.js·react
自由日记5 小时前
实例:跳动的心,火柴人
前端·css·css3
柯腾啊5 小时前
一文简单入门 Axios
前端·axios·apifox
im_AMBER6 小时前
React 15
前端·javascript·笔记·学习·react.js·前端框架
How_doyou_do6 小时前
模态框的两种管理思路
java·服务器·前端
snow@li6 小时前
前端:前端/浏览器 可以录屏吗 / 实践 / 录制 Microsoft Edge 标签页、应用窗口、整个屏幕
前端·浏览器录屏·前端录屏·web录屏
李贺梖梖6 小时前
CSS学习
前端·css
蚂小蚁7 小时前
一文吃透:宏任务、微任务、事件循环、浏览器渲染、Vue 批处理与 Node 差异(含性能优化)
前端·面试·架构