你可以使用Python的多线程来同时调用多个spotdl进程。下面是一个示例代码:
import os
import threading
def download(url):
command = f'spotdl {url}'
os.system(command)
urls = [
'https://open.spotify.com/album/4zL56l798hLfl3VP2eGIHY?si=I_jH2apuTv2g10mtBu69PA',
'https://open.spotify.com/track/5ghIJDpPoe3CfHMGu71E6T?si=7ULVpJq0SOKmL-Rwhs4oUQ',
'https://open.spotify.com/playlist/37i9dQZF1DXcBWIGoYBM5M?si=q5ZfXnSmSSKFTjLBK06A6g'
]
threads = []
for url in urls:
thread = threading.Thread(target=download, args=(url,))
thread.start()
threads.append(thread)
# 等待所有线程结束
for thread in threads:
thread.join()
在上面的代码中,我们定义了一个`download`函数来执行spotdl命令。然后,我们创建一个线程列表,并使用循环遍历每个URL。对于每个URL,我们创建一个新的线程,并将其启动。最后,我们使用`join`方法等待所有线程结束。
请注意,由于spotdl本身可能会有限制下载的数量和速率,同时下载太多文件可能会导致下载失败或延迟较长时间。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。 |