Update app.py
Browse filesSolve .MP3 decode mistake
app.py
CHANGED
|
@@ -1,10 +1,27 @@
|
|
| 1 |
import librosa
|
| 2 |
import numpy as np
|
| 3 |
import matplotlib.pyplot as plt
|
|
|
|
|
|
|
|
|
|
|
|
|
| 4 |
|
| 5 |
-
def
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 6 |
# 加载音频文件
|
| 7 |
y, sr = librosa.load(audio_file)
|
|
|
|
|
|
|
|
|
|
| 8 |
|
| 9 |
# 提取旋律(和声成分)
|
| 10 |
y_harmonic, y_percussive = librosa.effects.harmonic(y)
|
|
@@ -20,6 +37,14 @@ def extract_melody(audio_file):
|
|
| 20 |
plt.tight_layout()
|
| 21 |
plt.show()
|
| 22 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 23 |
# 替换为你的音频文件路径
|
| 24 |
audio_file = 'your_song.mp3'
|
| 25 |
extract_melody(audio_file)
|
|
|
|
| 1 |
import librosa
|
| 2 |
import numpy as np
|
| 3 |
import matplotlib.pyplot as plt
|
| 4 |
+
import librosa.display
|
| 5 |
+
import soundfile as sf
|
| 6 |
+
import os
|
| 7 |
+
from pydub import AudioSegment
|
| 8 |
|
| 9 |
+
def preprocess_audio(audio_file):
|
| 10 |
+
sound = AudioSegment.from_mp3(audio_file)
|
| 11 |
+
wav_file = audio_file.rsplit('.',1)[0]+'.wav'
|
| 12 |
+
sound.export(wav_file, format="wav" )
|
| 13 |
+
return wav_file
|
| 14 |
+
|
| 15 |
+
def extract_melody(audio_file,output_folder):
|
| 16 |
+
try:
|
| 17 |
+
# 预处理音频文件
|
| 18 |
+
audio_file = preprocess_audio(audio_file)
|
| 19 |
+
|
| 20 |
# 加载音频文件
|
| 21 |
y, sr = librosa.load(audio_file)
|
| 22 |
+
|
| 23 |
+
# 使用 HPSS 分离和声和打击乐成分
|
| 24 |
+
y_harmonic, y_percussive = librosa.effects.hpss(y)
|
| 25 |
|
| 26 |
# 提取旋律(和声成分)
|
| 27 |
y_harmonic, y_percussive = librosa.effects.harmonic(y)
|
|
|
|
| 37 |
plt.tight_layout()
|
| 38 |
plt.show()
|
| 39 |
|
| 40 |
+
# 保存提取的旋律
|
| 41 |
+
base_name = os.path.splitext(os.path.basename(audio_file))[0]
|
| 42 |
+
output_file = os.path.join(output_folder, f'extracted_melody_{base_name}.wav')
|
| 43 |
+
sf.write(output_file, y_harmonic, sr)
|
| 44 |
+
print(f"Extracted melody saved to: {output_file}")
|
| 45 |
+
except Exception as e:
|
| 46 |
+
print(f"An error occurred: {e}")
|
| 47 |
+
|
| 48 |
# 替换为你的音频文件路径
|
| 49 |
audio_file = 'your_song.mp3'
|
| 50 |
extract_melody(audio_file)
|