1
1
お題は不問!Qiita Engineer Festa 2024で記事投稿!
Qiita Engineer Festa20242024年7月17日まで開催中!

Python pydubで音声ファイルを操作しよう: 基本的な読み込みと保存

Last updated at Posted at 2024-07-14

はじめに

音声ファイルの操作は、多くのプログラミングプロジェクトで必要となる重要なスキルです。Pythonには、この作業を簡単に行えるライブラリがいくつかありますが、今回は特に使いやすさと機能の豊富さで知られるpydubを紹介します。

この記事では、pydubを使って音声ファイルを読み込み、操作し、保存する基本的な方法を解説します。

環境設定

まず、pydubをインストールしましょう。以下のコマンドをターミナルで実行します:

pip install pydub

注意: pydubは内部でffmpegを使用します。もしffmpegがインストールされていない場合は、FFmpegの公式サイトからダウンロードしてインストールしてください。

音声ファイルの読み込み

pydubでは、AudioSegmentクラスを使用して音声ファイルを読み込みます。様々な形式の音声ファイルに対応しています。

from pydub import AudioSegment

# WAVファイルの読み込み
wav_audio = AudioSegment.from_wav("audio_file.wav")

# MP3ファイルの読み込み
mp3_audio = AudioSegment.from_mp3("audio_file.mp3")

# OGGファイルの読み込み
ogg_audio = AudioSegment.from_ogg("audio_file.ogg")

# FLACファイルの読み込み
flac_audio = AudioSegment.from_file("audio_file.flac", "flac")

from_fileメソッドを使用すると、ファイルの拡張子に基づいて適切な読み込み方法を自動的に選択できます:

# ファイルの拡張子に基づいて自動的に読み込む
audio = AudioSegment.from_file("audio_file.mp3", format="mp3")

音声ファイルの基本情報の取得

読み込んだ音声ファイルの基本的な情報を取得してみましょう:

# 音声の長さ(ミリ秒)
duration_ms = len(audio)
print(f"音声の長さ: {duration_ms}ms")

# チャンネル数
channels = audio.channels
print(f"チャンネル数: {channels}")

# サンプルレート(Hz)
sample_rate = audio.frame_rate
print(f"サンプルレート: {sample_rate}Hz")

# ビット深度
sample_width = audio.sample_width
print(f"ビット深度: {sample_width * 8}ビット")

音声ファイルの操作

pydubを使用すると、音声ファイルに対して様々な操作を行うことができます。以下にいくつかの基本的な操作を紹介します:

1. 音量の調整

# 音量を6dB上げる
louder_audio = audio + 6

# 音量を3dB下げる
quieter_audio = audio - 3

2. 音声の一部を切り出す

# 最初の5秒を切り出す
first_5_seconds = audio[:5000]

# 30秒から35秒までの部分を切り出す
five_seconds = audio[30000:35000]

3. 音声ファイルの連結

# 2つの音声ファイルを連結する
combined = audio1 + audio2

4. フェードイン・フェードアウト

# 最初の1秒間でフェードイン
audio_with_fade_in = audio.fade_in(1000)

# 最後の1秒間でフェードアウト
audio_with_fade_out = audio.fade_out(1000)

音声ファイルの保存

操作した音声ファイルを保存するには、exportメソッドを使用します:

# WAVファイルとして保存
audio.export("output.wav", format="wav")

# MP3ファイルとして保存
audio.export("output.mp3", format="mp3")

# OGGファイルとして保存
audio.export("output.ogg", format="ogg")

# FLACファイルとして保存
audio.export("output.flac", format="flac")

MP3ファイルを保存する際に、ビットレートを指定することもできます:

# ビットレートを192kbpsに設定してMP3ファイルを保存
audio.export("output_192kbps.mp3", format="mp3", bitrate="192k")

サンプルコード:音声ファイルの読み込み、操作、保存

以下は、音声ファイルを読み込み、いくつかの操作を行い、新しいファイルとして保存する完全なサンプルコードです:

from pydub import AudioSegment

# 音声ファイルを読み込む
audio = AudioSegment.from_mp3("input.mp3")

# 音量を3dB上げる
louder_audio = audio + 3

# 最初の10秒を切り出す
first_10_seconds = louder_audio[:10000]

# フェードアウトを適用
audio_with_fade = first_10_seconds.fade_out(3000)

# 結果をWAVファイルとして保存
audio_with_fade.export("output.wav", format="wav")

print("処理が完了しました。output.wavを確認してください。")

このコードは、入力のMP3ファイルを読み込み、音量を上げ、最初の10秒を切り出し、最後の3秒間でフェードアウトを適用して、結果をWAVファイルとして保存します。

まとめ

この記事では、pydubを使用して音声ファイルを読み込み、基本的な操作を行い、保存する方法を紹介しました。pydubは非常に強力で使いやすいライブラリであり、これらの基本的な操作を組み合わせることで、複雑な音声処理タスクも実現できます。

音声ファイルの操作は、音楽制作、ポッドキャスト編集、音声分析など、さまざまな分野で活用できるスキルです。ぜひ、この記事で学んだ内容を基に、自分のプロジェクトでもpydubを活用してみてください。

参考リンク

1
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
1