music_genre / utils.py
admin
sync
58ca3ce
raw
history blame
1.72 kB
import os
import torch
import requests
from modelscope import snapshot_download
MODEL_DIR = snapshot_download(
"ccmusic-database/music_genre",
cache_dir="./__pycache__",
)
def toCUDA(x):
if hasattr(x, "cuda"):
if torch.cuda.is_available():
return x.cuda()
return x
def find_mp3_files(folder_path=f"{MODEL_DIR}/examples"):
wav_files = []
for root, _, files in os.walk(folder_path):
for file in files:
if file.endswith(".mp3"):
file_path = os.path.join(root, file)
wav_files.append(file_path)
return wav_files
def get_modelist(model_dir=MODEL_DIR):
try:
entries = os.listdir(model_dir)
except OSError as e:
print(f"无法访问 {model_dir}: {e}")
return
# 遍历所有条目
output = []
for entry in entries:
# 获取完整路径
full_path = os.path.join(model_dir, entry)
# 跳过'.git'文件夹
if entry == ".git" or entry == "examples":
print(f"跳过 .git / examples 文件夹: {full_path}")
continue
# 检查条目是文件还是目录
if os.path.isdir(full_path):
# 打印目录路径
output.append(os.path.basename(full_path))
return output
def download(url: str):
filename = url.split("/")[-1]
response = requests.get(url, stream=True)
if response.status_code == 200:
with open(filename, "wb") as f:
for chunk in response.iter_content(chunk_size=8192):
f.write(chunk)
print(f"文件已下载到 {os.getcwd()}/{filename}")
else:
print(f"下载失败,状态码:{response.status_code}")