phourxx
phourxx

Reputation: 621

Python convert mp3 to wav with Pydub

Ok, now I am stuck up in converting mp3 to wav. I have seen different answers but i think i would to go for the one of pydub, which i already did using these few lines

from pydub import AudioSegment

AudioSegment.from_mp3("/input/file.mp3").export("/output/file.wav", format="wav")

but when I run the above code, i get the following error

C:\Python27\lib\site-packages\pydub-0.14.2-py2.7.egg\pydub\utils.py:165: RuntimeWarning: Couldn't find ffmpeg or avconv - defaulting to ffmpeg, but may not work

Traceback (most recent call last): File "C:/Users/phourlhar/Desktop/VoiceDetector/yeah.py", line 7, in stereo_to_mono()

File "C:\Users\phourlhar\Desktop\VoiceDetector\utils.py", line 25, in stereo_to_mono

sound = AudioSegment.from_mp3(PROJECT_DIR+'\\files\\rec'+str(c)+'.mp3')

File "build\bdist.win32\egg\pydub\audio_segment.py", line 346, in from_file

File "C:\Python27\lib\subprocess.py", line 711, in init errread, errwrite)

File "C:\Python27\lib\subprocess.py", line 948, in _execute_child startupinfo)

WindowsError: [Error 2] The system cannot find the file specified

I don't know why it raises this error as i am very sure the file exists. Although i have answers suggesting the installation of ffmpeg, but i dont know if affect the app deployment in any way later on

Upvotes: 26

Views: 43144

Answers (4)

Etienne Jacquot
Etienne Jacquot

Reputation: 486

On Linux OS, using pydub with ffmpeg will also require a defualt location for ffprobe. Install FFMPeg for your Linux Distribution, and make sure the executables are in your PATH:

# Create a ffmpeg directory on AWS Linux
cd /usr/local/bin
mkdir ffmpeg && cd ffmpeg

# SET LATEST APP VERSION HERE
FFMPEG_APPVER='ffmpeg-7.0.2-amd64-static'

# Download and Unzip the ffmpeg binaries
wget https://johnvansickle.com/ffmpeg/releases/ffmpeg-release-amd64-static.tar.xz
tar -xf ffmpeg-release-amd64-static.tar.xz

# Copy extracted binaries to parent dir
cd /usr/local/bin/ffmpeg/$FFMPEG_APPVER/
cp -a /usr/local/bin/ffmpeg/$FFMPEG_APPVER/ . /usr/local/bin/ffmpeg/

# Create a symbolic link so ffmpeg and ffprobe are accessible inside of Python
ln -s /usr/local/bin/ffmpeg/ffmpeg /usr/bin/ffmpeg
ln -s /usr/local/bin/ffmpeg/ffprobe /usr/bin/ffprobe

You can now run python imports and set the AudioSegment values per documentation here: https://github.com/jiaaro/pydub

import ffmpeg
from pydub import AudioSegment

AudioSegment.converter = "/usr/bin/ffmpeg"
AudioSegment.ffmpeg = "/usr/bin/ffmpeg"
AudioSegment.ffprobe = "/usr/bin/ffprobe"

Upvotes: 0

Shuxuan XU
Shuxuan XU

Reputation: 29

The problem is due to the missing of ffmpeg. Pydub requires it to perform the operations of format conversion. To solve the problem, there are 2 ways:

  1. Simply install pydub with conda, not pip (despite the suggestion on Pydub's GitHub page)

    conda install -c conda-forge pydub
    

This should work fine. Reason unknown, possibly due to the compatibility stuff.

  1. The other solution (if you already used pip to install Pydub, and it does not work) is to install the missing ffmpeg package. Here comes another problem. Though we can find a package named ffmpeg on both pypi and anaconda, if we only installed one of the source, we will probably see the error like

    In [1]: import ffmpeg                                                                               
    ---------------------------------------------------------------------------
    ModuleNotFoundError                       Traceback (most recent call last)
    <ipython-input-1-16f5f3b4de71> in <module>
    ----> 1 import ffmpeg
    
    ModuleNotFoundError: No module named 'ffmpeg'
    

After several tests, I found that both have to be installed to make the package ffmpeg work (install twice, in other words). Otherwise, somehow python cannot find the package even if it has been installed via either pip or anaconda. So just type

pip install ffmpeg
conda install ffmpeg

Now try to import ffmpeg in python. If there is no error, the problem should already be solved.

NOTE that, manually downloading ffmpeg from FFmpeg website and append the bin path to sys.path might not help with this problem. Similarly, manually specifying the path to the executable of ffmpeg (on Windows it is ffmpeg.exe) might not solve the problem either.

Upvotes: 0

Abhishek Rathore
Abhishek Rathore

Reputation: 1186

You must go for pydub, it is a great module for operations related with audio files.

NOTE. Do remember to install ffmpeg before you use pydub.

For help regarding installation of ffmpeg, you can use this link.

Then to install pydub just open your command prompt and type

pip install pydub

Then to convert any file from mp3 to wav just use pydub as

import pydub
sound = pydub.AudioSegment.from_mp3("D:/example/apple.mp3")
sound.export("D:/example/apple.wav", format="wav")

Upvotes: 14

Roland Smith
Roland Smith

Reputation: 43533

The pydub module uses either ffmpeg or avconf programs to do the actual conversion. So you do have to install ffmpeg to make this work.

But if you don't need pydub for anything else, you can just use the built-in subprocess module to call a convertor program like ffmpeg like this:

  import subprocess

  subprocess.call(['ffmpeg', '-i', '/input/file.mp3',
                   '/output/file.wav'])

This requires that the ffmpeg binary is in a location in your $PATH, by the way.

Edit: With ffmeg, you cannot convert stereo to mono, as far as I know. You can only choose the left or right channel. I'm assuming this is not what you want.

The sox program can convert stereo to mono:

  import subprocess

  subprocess.call(['sox', '/input/file.mp3', '-e', 'mu-law', 
                   '-r', '16k', '/output/file.wav', 'remix', '1,2'])

This will sample at 16 kHz, with 8 bits/sample, giving you 16 kb/s.

Upvotes: 21

Related Questions