Python: 如何使用speech_recognition 將wav檔轉為文字?

加入好友
加入社群
Python: 如何使用speech_recognition 將wav檔轉為文字? - 儲蓄保險王

前置作業(安裝套件):
pip install SpeechRecognition
#請注意: pip install SpeechRecognition
但是在py code中是import speech_recognition
兩者並不一致

为什么会有这种差异?
这种差异主要是因为PyPI上的包名(SpeechRecognition)和库内部使用的模块名(speech_recognition)可以不同。包名通常是为了易读性和易记性而设计的,而模块名则遵循Python的命名约定,通常是小写字母且有时会包含下划线以提高可读性。

总结
使用pip install SpeechRecognition来安装库。
使用import speech_recognition as sr来在你的Python脚本中导入和使用这个库。
这样的命名方式虽然可能初看起来有点迷惑,但只要理解了包名和模块名的使用场景和区别,就能够顺利地使用这些库了。希望这能帮助您更好地理解和使用SpeechRecognition库!

FFMPEG下載

# -*- coding: utf-8 -*-
"""
Created on Thu Sep  5 09:59:00 2024

@author: SavingKing
"""

import speech_recognition as sr

# 初始化识别器
r = sr.Recognizer()

# 从音频文件中加载音频
with sr.AudioFile('我的錄音_中文測試.wav') as source:
    audio = r.record(source)  # 读取整个音频文件

# 使用Google Web Speech API进行识别
try:
    print("Google Speech Recognition thinks you said:")
    print(r.recognize_google(audio, language='zh-CN'))  # 假设是中文
except sr.UnknownValueError:
    print("Google Speech Recognition could not understand audio")
except sr.RequestError as e:
    print(f"Could not request results from Google Speech Recognition service; {e}")
    

輸出結果:

Python: 如何使用speech_recognition 將wav檔轉為文字? - 儲蓄保險王

在語音識別庫中,language=”zh-TW” 指的是使用台灣的中文,這通常是指繁體中文。而簡體中文通常是通過 language=”zh-CN” 來指定的。

繁體中文:使用 language=”zh-TW” 或 language=”zh-HK”(香港的繁體中文)。對於台灣的中文(繁體),就使用 zh-TW。
簡體中文:使用 language=”zh-CN”,這是指中國大陸的簡體中文。

sr.AudioFile?

Python: 如何使用speech_recognition 將wav檔轉為文字? - 儲蓄保險王

Init signature: sr.AudioFile(filename_or_fileobject)
Docstring:
Creates a new AudioFile instance given a WAV/AIFF/FLAC audio file filename_or_fileobject. Subclass of AudioSource.

If filename_or_fileobject is a string, then it is interpreted as a path to an audio file on the filesystem. Otherwise, filename_or_fileobject should be a file-like object such as io.BytesIO or similar.

Note that functions that read from the audio (such as recognizer_instance.record or recognizer_instance.listen) will move ahead in the stream. For example, if you execute recognizer_instance.record(audiofile_instance, duration=10) twice, the first time it will return the first 10 seconds of audio, and the second time it will return the 10 seconds of audio right after that. This is always reset to the beginning when entering an AudioFile context.

WAV files must be in PCM/LPCM format; WAVE_FORMAT_EXTENSIBLE and compressed WAV are not supported and may result in undefined behaviour.

Both AIFF and AIFF-C (compressed AIFF) formats are supported.

FLAC files must be in native FLAC format; OGG-FLAC is not supported and may result in undefined behaviour.
File: c:\users\iec120639\appdata\local\anaconda3\lib\site-packages\speech_recognition__init__.py
Type: type
Subclasses:

sr.AudioFile 是一個用於處理音訊檔案的類別,它是 AudioSource 的子類別。可以讀取 WAV、AIFF 和 FLAC 格式的音檔。

  • 參數filename_or_fileobject 可以是檔案路徑(字串)或類似 io.BytesIO 的檔案物件。
  • 行為:如果多次讀取音檔(例如使用 recognizer_instance.record),音訊流會向前移動。每次進入 AudioFile 的上下文時,流會重置到開頭。
  • 格式限制
    • WAV 必須是 PCM/LPCM 格式,不支援壓縮的 WAV。
    • 支援 AIFF 和 AIFF-C 格式。
    • FLAC 必須是原生 FLAC 格式,不支援 OGG-FLAC。

使用這個類別可以方便地從音訊檔案中獲取數據進行語音辨識。

r.recognize_google(audio, language=’zh-TW’
無法處理大型音檔(bad request),
先將大型音檔用pydub切割為多個小音檔
再使用glob.glob()建立多音檔路徑的list
批次處理每一個音檔
code:

# -*- coding: utf-8 -*-
"""
Created on Thu Sep  5 06:59:00 2024

@author: SavingKing
ver02:
    要用glob.glob() 做多檔案處理
"""

import speech_recognition as sr
import glob
import os

def mkdir_export(dirname, strr="export"):
    dirname_export = os.path.join(dirname, strr)
    if not os.path.exists(dirname_export):
        os.mkdir(dirname_export)
        print(f"已經建立資料夾: {dirname_export}")
    else:
        print(f"資料夾已經存在: {dirname_export}")
    return dirname_export

dirname  = r"D:\user\Python\speech\split"
basename = "*.wav"
lis_path = glob.glob( os.path.join(dirname,basename) )
# len(lis_path)
# Out[54]: 1232

# 初始化识别器
r = sr.Recognizer()

strr=""
for p in lis_path:
    # 从音频文件中加载音频
    with sr.AudioFile(p) as source:
        audio = r.record(source)  # 读取整个音频文件
    
    # 使用Google Web Speech API进行识别
    try:
        strr += r.recognize_google(audio, language='zh-TW')  # 假设是中文
        print("Google Speech Recognition已將辨識內容添加進strr變數中")
    except sr.UnknownValueError as e:
        print(f"Google Speech Recognition could not understand audio:{e}")
    except sr.RequestError as e:
        print(f"Could not request results from Google Speech Recognition service; {e}")

dir_export = mkdir_export(dirname, strr="export")
basename_txt = "逐字稿.txt"
path_txt = os.path.join( dir_export, basename_txt)

with open(path_txt,"w") as f:
    f.write(strr)
print(f"逐字稿已經輸出到{path_txt}")

修訂code:

# -*- coding: utf-8 -*-
"""
Created on Thu Sep  5 06:59:00 2024

@author: SavingKing
ver02:
    要用glob.glob() 做多檔案處理
"""

import speech_recognition as sr
import glob
import os

def mkdir_export(dirname, strr="export"):
    dirname_export = os.path.join(dirname, strr)
    if not os.path.exists(dirname_export):
        os.mkdir(dirname_export)
        print(f"已經建立資料夾: {dirname_export}")
    else:
        print(f"資料夾已經存在: {dirname_export}")
    return dirname_export

dirname = r"D:\user\Python\speech\Jeff240719\split"
basename = "*.wav"
lis_path = glob.glob(os.path.join(dirname, basename))

# 初始化识别器
r = sr.Recognizer()

dir_export = mkdir_export(dirname, strr="export")
basename_txt = "逐字稿.txt"
path_txt = os.path.join(dir_export, basename_txt)

# 打开文件准备写入识别结果
with open(path_txt, "w") as f: #使用"a"模式更加
    for p in lis_path:
        # 从音频文件中加载音频
        with sr.AudioFile(p) as source:
            audio = r.record(source)  # 读取整个音频文件
        
        # 使用Google Web Speech API进行识别
        try:
            text = r.recognize_google(audio, language='zh-TW') + "\n"  # 假设是中文
            f.write(text)  # 直接写入文件
            print("已将辨識内容写入文件")
        except sr.UnknownValueError:
            print("无法理解音频")
        except sr.RequestError as e:
            print(f"无法从Google Speech Recognition服务获取结果: {e}")

print(f"逐字稿已經輸出到{path_txt}")

改進點:
逐步寫入:我們不再等待所有音頻處理完畢後再寫入文件,而是每識別完一個文件的內容後立即寫入。這樣可以減少數據丟失的風險。
異常處理:在識別和文件寫入過程中加入了異常處理,確保即使一部分音頻識別失敗或發生寫入錯誤,程序也能繼續處理其他音頻文件。
日志輸出:通過控制台輸出信息來追蹤處理進度,有助於了解當前任務執行情況和可能出現的錯誤。

推薦hahow線上學習python: https://igrape.net/30afN

加入好友
加入社群
Python: 如何使用speech_recognition 將wav檔轉為文字? - 儲蓄保險王

儲蓄保險王

儲蓄險是板主最喜愛的儲蓄工具,最喜愛的投資理財工具則是ETF,最喜愛的省錢工具則是信用卡

You may also like...

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *