This commit is contained in:
holwell 2025-02-14 16:39:41 +08:00 committed by GitHub
commit 95c232d72e
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 77 additions and 22 deletions

6
.gitignore vendored Normal file
View File

@ -0,0 +1,6 @@
__pycache__/
.history/
neteasecloudmusicapi/
cookies.txt
failed_ids.txt
*.json

93
main.py
View File

@ -1,5 +1,6 @@
import os
import json
from typing import Union
import requests
import time
@ -66,6 +67,21 @@ def get_song_details(song_ids):
print("响应内容无法解析为JSON:", response.text)
return []
# 判断歌曲是否已上传云盘
def has_uploaded(song_id, cookie):
url = f"http://localhost:3000/user/cloud/detail?id={song_id}&cookie={cookie}"
response = requests.get(url)
try:
response_data = response.json()
if response_data.get('code') == 200 and len(response_data['data']) != 0:
return True
else:
print("获取云盘歌曲详情失败:", response_data.get("message"))
return False
except json.JSONDecodeError:
print("获取云盘歌曲信息失败响应内容无法解析为JSON:", response.text)
return False
# 执行 import 请求
def import_song(song_info, cookie):
song_id = song_info['id']
@ -93,6 +109,14 @@ def import_song(song_info, cookie):
def save_failed_id(song_id):
with open("failed_ids.txt", "a") as f:
f.write(f"{song_id}\n")
# 获取最后一个上传的异常 id
def get_last_failed_id() -> Union[int, None]:
if not os.path.exists("failed_ids.txt"):
return None
with open("failed_ids.txt", "r") as f:
ids = [line.strip() for line in f]
return int(ids[-1])
# 处理歌曲导入请求
def process_songs(song_info_list, cookie):
@ -100,7 +124,12 @@ def process_songs(song_info_list, cookie):
for song_info in song_info_list:
song_id = song_info['id']
print(f"正在导入歌曲ID: {song_id}")
# 已上传则跳过
if has_uploaded(song_id, cookie):
print('该歌曲已上传,跳过!')
continue
# 查询歌曲的详细信息
song_details = get_song_details([song_id])
if song_details:
@ -111,30 +140,47 @@ def process_songs(song_info_list, cookie):
# 更新 song_info 添加 artist 和 album 信息
song_info['artist'] = song_artist
song_info['album'] = song_album
try:
try_to_upload_song(song_info, cookie)
except Exception as e:
print(f'上传过程异常,跳过该歌曲:{e}')
save_failed_id(song_id)
def try_to_upload_song(song_info, cookie):
song_id = song_info['id']
attempts = 0
while attempts < 3:
result = import_song(song_info, cookie)
attempts = 0
while attempts < 3:
result = import_song(song_info, cookie)
if result:
success_songs = result.get('data', {}).get('successSongs', [])
failed = result.get('data', {}).get('failed', [])
if result:
success_songs = result.get('data', {}).get('successSongs', [])
failed = result.get('data', {}).get('failed', [])
if success_songs:
print(f"歌曲 {song_id} 导入成功!")
break # 成功则跳出循环
else:
print(f"歌曲 {song_id} 导入失败,失败原因:{failed}")
if all(f['code'] == -100 for f in failed): # 文件已存在的错误码
print(f"歌曲 {song_id} 文件已存在,跳过")
save_failed_id(song_id) # 保存失败的 ID
break
time.sleep(5) # 请求失败后等待 5 秒重新请求
attempts += 1
if success_songs:
print(f"歌曲 {song_id} 导入成功!")
break # 成功则跳出循环
else:
print(f"歌曲 {song_id} 导入失败,失败原因:{failed}")
if all(f['code'] == -100 for f in failed): # 文件已存在的错误码
print(f"歌曲 {song_id} 文件已存在,跳过")
save_failed_id(song_id) # 保存失败的 ID
break
time.sleep(5) # 请求失败后等待 5 秒重新请求
attempts += 1
if attempts == 3: # 如果失败三次,则跳过此 ID
print(f"歌曲 {song_id} 失败三次,跳过该歌曲。")
save_failed_id(song_id) # 保存失败的 ID
if attempts == 3: # 如果失败三次,则跳过此 ID
print(f"歌曲 {song_id} 失败三次,跳过该歌曲。")
save_failed_id(song_id) # 保存失败的 ID
def get_resume_song_info_list(song_info_list) -> list:
last_failed_id = get_last_failed_id()
if last_failed_id is None:
print("暂无上传失败记录,从头开始上传")
return
for index, song_info in enumerate(song_info_list):
if int(song_info['id']) == last_failed_id:
print(f"当前已上传: {index + 1},最后上传失败的 id: {song_info['id']}")
return song_info_list[index + 1:]
# 主函数
def main():
@ -165,6 +211,9 @@ def main():
song_info_list = get_all_song_info(songs_data)
#print(f"所有歌曲信息: {song_info_list}")
# 从上次失败的歌曲开始上传
song_info_list = get_resume_song_info_list(song_info_list)
# 执行歌曲导入请求
process_songs(song_info_list, cookie)
else: