IndexTTS-2-Demo-bak / tools /download_files.py
kemuriririn's picture
fix
ad57b15
import requests
import zipfile
import os
import argparse
def get_confirm_token(response):
"""
从响应中检查是否存在下载确认令牌(cookie)
Args:
response (requests.Response): 响应对象
Returns:
str: 确认令牌的值(如果存在),否则为None
"""
for key, value in response.cookies.items():
if key.startswith('download_warning'): # 确认令牌的cookie通常以这个开头
return value
return None
def save_response_content(response, destination, chunk_size=32768):
"""
以流式方式将响应内容写入文件,支持大文件下载。
Args:
response (requests.Response): 流式响应对象
destination (str): 本地保存路径
chunk_size (int, optional): 每次迭代写入的块大小. Defaults to 32768.
"""
with open(destination, "wb") as f:
for chunk in response.iter_content(chunk_size):
if chunk: # 过滤掉保持连接的空白块
f.write(chunk)
def download_model_from_modelscope(destination,hf_cache_dir):
print(f"[ModelScope] Downloading models to {destination},model cache dir={hf_cache_dir}")
from modelscope import snapshot_download
snapshot_download("IndexTeam/IndexTTS-2", local_dir=destination)
snapshot_download("amphion/MaskGCT", local_dir=os.path.join(hf_cache_dir,"models--amphion--MaskGCT"))
snapshot_download("facebook/w2v-bert-2.0",local_dir=os.path.join(hf_cache_dir,"models--facebook--w2v-bert-2.0"))
snapshot_download("nv-community/bigvgan_v2_22khz_80band_256x",local_dir=os.path.join(hf_cache_dir,"models--nvidia--bigvgan_v2_22khz_80band_256x"))
snapshot_download("iic/speech_campplus_sv_zh-cn_16k-common",local_dir=os.path.join(hf_cache_dir,"models--funasr--campplus"))
def download_model_from_huggingface(destination,hf_cache_dir):
print(f"[HuggingFace] Downloading models to {destination},model cache dir={hf_cache_dir}")
from huggingface_hub import snapshot_download
snapshot_download("IndexTeam/IndexTTS-2", local_dir=destination)
# snapshot_download("amphion/MaskGCT", local_dir=os.path.join(hf_cache_dir,"models--amphion--MaskGCT"))
# snapshot_download("facebook/w2v-bert-2.0",local_dir=os.path.join(hf_cache_dir,"models--facebook--w2v-bert-2.0"))
# snapshot_download("nvidia/bigvgan_v2_22khz_80band_256x",local_dir=os.path.join(hf_cache_dir, "models--nvidia--bigvgan_v2_22khz_80band_256x"))
# snapshot_download("funasr/campplus",local_dir=os.path.join(hf_cache_dir,"models--funasr--campplus"))
# 使用示例
if __name__ == "__main__":
parser = argparse.ArgumentParser(description="Download models and example files")
parser.add_argument('-s','--model_source', choices=['modelscope', 'huggingface'], default=None, help='Model source')
args = parser.parse_args()
if args.model_source:
if args.model_source == 'modelscope':
download_model_from_modelscope("checkpoints",os.path.join("checkpoints","hf_cache"))
elif args.model_source == 'huggingface':
download_model_from_huggingface("checkpoints",os.path.join("checkpoints","hf_cache"))