jdk21使用Vosk实现语音文字转换,免费的语音识别

1.下载vosk的model

vosk官网:https://alphacephei.com/vosk/models

我这里使用较小的vosk-model-small-cn-0.22

2.添加相关pom文件

java 复制代码
 <!-- 获取音频信息 -->
        <dependency>
            <groupId>org</groupId>
            <artifactId>jaudiotagger</artifactId>
            <version>2.0.3</version>
        </dependency>

        <!-- 语音识别 -->
        <dependency>
            <groupId>net.java.dev.jna</groupId>
            <artifactId>jna</artifactId>
            <version>5.16.0</version>
        </dependency>
        <dependency>
            <groupId>com.alphacephei</groupId>
            <artifactId>vosk</artifactId>
            <version>0.3.45</version>
        </dependency>

3.代码

添加model和使用的音频,我这里用的wav格式的,不同格式的参数会不一样

java 复制代码
import org.vosk.LibVosk;
import org.vosk.LogLevel;
import org.vosk.Model;
import org.vosk.Recognizer;

import javax.sound.sampled.AudioSystem;
import javax.sound.sampled.UnsupportedAudioFileException;
import java.io.*; 

public class testVosk {
    public static void main(String[] argv) throws IOException, UnsupportedAudioFileException {
        LibVosk.setLogLevel(LogLevel.DEBUG);

        try (Model model = new Model("E:\\srk\\bigData\\vosk-model-small-cn-0.22");
             InputStream fis = AudioSystem.getAudioInputStream(new BufferedInputStream(new FileInputStream("C:\\Users\\Administrator\\Downloads\\mdhs1-5ob2k.wav")));
             Recognizer recognizer = new Recognizer(model, 16000)) {
            int bytes;
            byte[] b = new byte[4096];
            while ((bytes = fis.read(b)) >= 0) {
                if (recognizer.acceptWaveForm(b, bytes)) {
                    System.out.println(recognizer.getResult());
                } else {
                    System.out.println(recognizer.getPartialResult());
                }
            }
            String result = recognizer.getFinalResult();
            System.out.println(result);
        }

    }
}

4.可能遇到的问题

1.乱码,我搞了半天(捂脸)

因为jdk17以后编号的模式改了,所以在网上找了各种设置编码的格式都没有生效。

比如jvm设置 -Dfile.encoding=UTF-8都没生效。

-Dfile.encoding=UTF-8

jdk17以前的还是正常的。

解决方法:

  1. win系统控制面板找到"区域与语言设置"

  2. 在弹出框中选择更改系统区域设置

  3. 勾选beta使用utf-8

5.相关资料

  1. gitcode相关api
相关推荐
Yo_Becky14 分钟前
【PyTorch】PyTorch预训练模型缓存位置迁移,也可拓展应用于其他文件的迁移
人工智能·pytorch·经验分享·笔记·python·程序人生·其他
guojl14 分钟前
Java多任务编排技术
java
DeepSeek-大模型系统教程16 分钟前
深入金融与多模态场景实战:金融文档分块技术与案例汇总
人工智能·ai·语言模型·程序员·大模型·大模型学习·大模型教程
xinxiangwangzhi_21 分钟前
pytorch底层原理学习--PyTorch 架构梳理
人工智能·pytorch·架构
丶意冷22 分钟前
mybatisPlus分页方言设置错误问题 mybatisPlus对于Oceanbase的Oracle租户分页识别错误
java·数据库·oracle·oceanbase
yzx99101325 分钟前
关于网络协议
网络·人工智能·python·网络协议
AiTEN_Robot27 分钟前
AGV 无人叉车关键技术问题解析:精准定位算法 / 安全避障逻辑 / 系统对接协议全方案
人工智能·机器人·自动化·制造
云天徽上28 分钟前
【PaddleOCR】OCR常见关键信息抽取数据集,包含FUNSD、XFUND、WildReceipt等整理,持续更新中......
人工智能·计算机视觉·信息可视化·paddlepaddle·paddleocr·文本识别
zskj_zhyl28 分钟前
智绅科技:以科技为翼,构建养老安全守护网
人工智能·科技·安全
刘海东刘海东29 分钟前
结构型智能科技的关键可行性——信息型智能向结构型智能的转换(提纲)
人工智能