Spaces:
Sleeping
Sleeping
File size: 1,741 Bytes
710844b c9d9c2a 710844b c9d9c2a 710844b c9d9c2a 710844b c9d9c2a 710844b c9d9c2a 710844b c9d9c2a 710844b c9d9c2a 710844b c9d9c2a 710844b |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 |
import gradio as gr
from pydub import AudioSegment
import tempfile
import os
from math import log10
def change_volume(audio_path, mode, value):
if audio_path is None:
return "エラー: 音声ファイルがありません"
# 音声読み込み
audio = AudioSegment.from_file(audio_path)
# 音量調整
try:
if mode == "パーセンテージ(%)":
multiplier = 1 + float(value) / 100
if multiplier <= 0:
return "エラー: 0%以下にはできません"
db_gain = 10 * log10(multiplier)
audio = audio.apply_gain(db_gain)
elif mode == "デシベル(dB)":
db_value = float(value)
audio = audio + db_value
else:
return "エラー: モードが不正です"
except Exception as e:
return f"エラー: 数値が不正です ({e})"
# 出力
out_path = tempfile.NamedTemporaryFile(delete=False, suffix=".wav").name
audio.export(out_path, format="wav")
return out_path
# Gradio UI
with gr.Blocks() as app:
gr.Markdown("## 🎚️ 音量調整アプリ(% または dB)")
with gr.Row():
audio_input = gr.Audio(type="filepath", label="音声ファイルをアップロード")
audio_output = gr.Audio(label="出力音声", interactive=False)
with gr.Row():
mode = gr.Radio(["パーセンテージ(%)", "デシベル(dB)"], value="パーセンテージ(%)", label="調整モード")
value = gr.Textbox(label="調整値(例:50, -10 など)")
run_btn = gr.Button("音量を変更")
run_btn.click(fn=change_volume, inputs=[audio_input, mode, value], outputs=audio_output)
app.launch()
|