Merge branch 'master' into dev
This commit is contained in:
124
core.py
124
core.py
@@ -72,11 +72,14 @@ def get_info(json_data): # 返回json里的数据
|
||||
return title, studio, year, outline, runtime, director, actor_photo, release, number, cover, trailer, website, series, label
|
||||
|
||||
|
||||
def small_cover_check(path, filename, cover_small, movie_path, json_data=None):
|
||||
def small_cover_check(path, filename, cover_small, movie_path, json_headers=None):
|
||||
full_filepath = Path(path) / filename
|
||||
if config.getInstance().download_only_missing_images() and not file_not_exist_or_empty(str(full_filepath)):
|
||||
return
|
||||
download_file_with_filename(cover_small, filename, path, movie_path, json_data)
|
||||
if json_headers != None:
|
||||
download_file_with_filename(cover_small, filename, path, movie_path, json_headers['headers'])
|
||||
else:
|
||||
download_file_with_filename(cover_small, filename, path, movie_path)
|
||||
print('[+]Image Downloaded! ' + full_filepath.name)
|
||||
|
||||
|
||||
@@ -120,57 +123,28 @@ def download_file_with_filename(url, filename, path, filepath, json_headers=None
|
||||
|
||||
for i in range(configProxy.retry):
|
||||
try:
|
||||
if configProxy.enable:
|
||||
if not os.path.exists(path):
|
||||
try:
|
||||
os.makedirs(path)
|
||||
except:
|
||||
print(f"[-]Fatal error! Can not make folder '{path}'")
|
||||
os._exit(0)
|
||||
proxies = configProxy.proxies()
|
||||
headers = {'User-Agent': G_USER_AGENT}
|
||||
if json_headers != None:
|
||||
headers.update(json_headers)
|
||||
r = requests.get(url, headers=headers, timeout=configProxy.timeout, proxies=proxies)
|
||||
if r == '':
|
||||
print('[-]Movie Download Data not found!')
|
||||
return
|
||||
with open(os.path.join(path, filename), "wb") as code:
|
||||
code.write(r.content)
|
||||
if not os.path.exists(path):
|
||||
try:
|
||||
os.makedirs(path)
|
||||
except:
|
||||
print(f"[-]Fatal error! Can not make folder '{path}'")
|
||||
os._exit(0)
|
||||
r = get_html(url=url,return_type='content',json_headers=json_headers)
|
||||
if r == '':
|
||||
print('[-]Movie Download Data not found!')
|
||||
return
|
||||
else:
|
||||
if not os.path.exists(path):
|
||||
try:
|
||||
os.makedirs(path)
|
||||
except:
|
||||
print(f"[-]Fatal error! Can not make folder '{path}'")
|
||||
os._exit(0)
|
||||
headers = {'User-Agent': G_USER_AGENT}
|
||||
if json_headers != None:
|
||||
headers.update(json_headers)
|
||||
r = requests.get(url, timeout=configProxy.timeout, headers=headers)
|
||||
if r == '':
|
||||
print('[-]Movie Download Data not found!')
|
||||
return
|
||||
with open(os.path.join(path, filename), "wb") as code:
|
||||
code.write(r.content)
|
||||
return
|
||||
except requests.exceptions.RequestException:
|
||||
i += 1
|
||||
print('[-]Image Download : Connect retry ' + str(i) + '/' + str(configProxy.retry))
|
||||
except requests.exceptions.ConnectionError:
|
||||
i += 1
|
||||
print('[-]Image Download : Connect retry ' + str(i) + '/' + str(configProxy.retry))
|
||||
with open(os.path.join(path, filename), "wb") as code:
|
||||
code.write(r)
|
||||
return
|
||||
except requests.exceptions.ProxyError:
|
||||
i += 1
|
||||
print('[-]Image Download : Connect retry ' + str(i) + '/' + str(configProxy.retry))
|
||||
except requests.exceptions.ConnectTimeout:
|
||||
i += 1
|
||||
print('[-]Image Download : Connect retry ' + str(i) + '/' + str(configProxy.retry))
|
||||
except IOError:
|
||||
print(f"[-]Create Directory '{path}' failed!")
|
||||
moveFailedFolder(filepath)
|
||||
return
|
||||
print('[-]Image Download : Proxy error ' + str(i) + '/' + str(configProxy.retry))
|
||||
# except IOError:
|
||||
# print(f"[-]Create Directory '{path}' failed!")
|
||||
# moveFailedFolder(filepath)
|
||||
# return
|
||||
except Exception as e:
|
||||
print('[-]Image Download :Error',e)
|
||||
print('[-]Connect Failed! Please check your Proxy or Network!')
|
||||
moveFailedFolder(filepath)
|
||||
return
|
||||
@@ -303,12 +277,12 @@ def image_ext(url):
|
||||
|
||||
|
||||
# 封面是否下载成功,否则移动到failed
|
||||
def image_download(cover, fanart_path, thumb_path, path, filepath, json_data):
|
||||
def image_download(cover, fanart_path, thumb_path, path, filepath, json_headers=None):
|
||||
full_filepath = os.path.join(path, fanart_path)
|
||||
if config.getInstance().download_only_missing_images() and not file_not_exist_or_empty(full_filepath):
|
||||
return
|
||||
if "headers" in json_data:
|
||||
if download_file_with_filename(cover, fanart_path, path, filepath, json_data['headers']) == 'failed':
|
||||
if json_headers != None:
|
||||
if download_file_with_filename(cover, fanart_path, path, filepath, json_headers['headers']) == 'failed':
|
||||
moveFailedFolder(filepath)
|
||||
return
|
||||
else:
|
||||
@@ -320,8 +294,8 @@ def image_download(cover, fanart_path, thumb_path, path, filepath, json_data):
|
||||
for i in range(configProxy.retry):
|
||||
if file_not_exist_or_empty(full_filepath):
|
||||
print('[!]Image Download Failed! Trying again. [{}/3]', i + 1)
|
||||
if "headers" in json_data:
|
||||
download_file_with_filename(cover, fanart_path, path, filepath, json_data['headers'])
|
||||
if json_headers != None:
|
||||
download_file_with_filename(cover, fanart_path, path, filepath, json_headers['headers'])
|
||||
else:
|
||||
download_file_with_filename(cover, fanart_path, path, filepath)
|
||||
continue
|
||||
@@ -364,8 +338,10 @@ def print_files(path, leak_word, c_word, naming_rule, part, cn_sub, json_data, f
|
||||
print(" <sorttitle><![CDATA[" + naming_rule + "]]></sorttitle>", file=code)
|
||||
print(" <customrating>JP-18+</customrating>", file=code)
|
||||
print(" <mpaa>JP-18+</mpaa>", file=code)
|
||||
print(" <set>", file=code)
|
||||
print(" </set>", file=code)
|
||||
try:
|
||||
print(" <set>" + series + "</set>", file=code)
|
||||
except:
|
||||
print(" <set></set>", file=code)
|
||||
print(" <studio>" + studio + "</studio>", file=code)
|
||||
print(" <year>" + year + "</year>", file=code)
|
||||
print(" <outline><![CDATA[" + outline + "]]></outline>", file=code)
|
||||
@@ -399,7 +375,7 @@ def print_files(path, leak_word, c_word, naming_rule, part, cn_sub, json_data, f
|
||||
try:
|
||||
for i in tag:
|
||||
print(" <tag>" + i + "</tag>", file=code)
|
||||
print(" <tag>" + series + "</tag>", file=code)
|
||||
# print(" <tag>" + series + "</tag>", file=code)
|
||||
except:
|
||||
aaaaa = ''
|
||||
if cn_sub == '1':
|
||||
@@ -413,7 +389,7 @@ def print_files(path, leak_word, c_word, naming_rule, part, cn_sub, json_data, f
|
||||
try:
|
||||
for i in tag:
|
||||
print(" <genre>" + i + "</genre>", file=code)
|
||||
print(" <genre>" + series + "</genre>", file=code)
|
||||
# print(" <genre>" + series + "</genre>", file=code)
|
||||
except:
|
||||
aaaaaaaa = ''
|
||||
print(" <num>" + number + "</num>", file=code)
|
||||
@@ -864,10 +840,16 @@ def core_main(movie_path, number_th, oCC):
|
||||
|
||||
# 检查小封面, 如果image cut为3,则下载小封面
|
||||
if imagecut == 3:
|
||||
small_cover_check(path, poster_path, json_data.get('cover_small'), movie_path, json_data)
|
||||
if 'headers' in json_data:
|
||||
small_cover_check(path, poster_path, json_data.get('cover_small'), movie_path, json_data)
|
||||
else:
|
||||
small_cover_check(path, poster_path, json_data.get('cover_small'), movie_path)
|
||||
|
||||
# creatFolder会返回番号路径
|
||||
image_download( cover, fanart_path,thumb_path, path, movie_path, json_data)
|
||||
if 'headers' in json_data:
|
||||
image_download(cover, fanart_path, thumb_path, path, movie_path, json_data)
|
||||
else:
|
||||
image_download(cover, fanart_path, thumb_path, path, movie_path)
|
||||
|
||||
if not multi_part or part.lower() == '-cd1':
|
||||
try:
|
||||
@@ -877,7 +859,10 @@ def core_main(movie_path, number_th, oCC):
|
||||
|
||||
# 下载剧照 data, path, filepath
|
||||
if conf.is_extrafanart() and json_data.get('extrafanart'):
|
||||
extrafanart_download(json_data.get('extrafanart'), path, number, movie_path, json_data)
|
||||
if 'headers' in json_data:
|
||||
extrafanart_download(json_data.get('extrafanart'), path, number, movie_path, json_data)
|
||||
else:
|
||||
extrafanart_download(json_data.get('extrafanart'), path, number, movie_path)
|
||||
|
||||
# 下载演员头像 KODI .actors 目录位置
|
||||
if conf.download_actor_photo_for_kodi():
|
||||
@@ -918,10 +903,16 @@ def core_main(movie_path, number_th, oCC):
|
||||
|
||||
# 检查小封面, 如果image cut为3,则下载小封面
|
||||
if imagecut == 3:
|
||||
small_cover_check(path, poster_path, json_data.get('cover_small'), movie_path, json_data)
|
||||
if 'headers' in json_data:
|
||||
small_cover_check(path, poster_path, json_data.get('cover_small'), movie_path, json_data)
|
||||
else:
|
||||
small_cover_check(path, poster_path, json_data.get('cover_small'), movie_path)
|
||||
|
||||
# creatFolder会返回番号路径
|
||||
image_download( cover, fanart_path, thumb_path, path, movie_path)
|
||||
if 'headers' in json_data:
|
||||
image_download(cover, fanart_path, thumb_path, path, movie_path, json_data)
|
||||
else:
|
||||
image_download(cover, fanart_path, thumb_path, path, movie_path)
|
||||
|
||||
if not multi_part or part.lower() == '-cd1':
|
||||
try:
|
||||
@@ -931,7 +922,10 @@ def core_main(movie_path, number_th, oCC):
|
||||
|
||||
# 下载剧照 data, path, filepath
|
||||
if conf.is_extrafanart() and json_data.get('extrafanart'):
|
||||
extrafanart_download(json_data.get('extrafanart'), path, number, movie_path, json_data)
|
||||
if 'headers' in json_data:
|
||||
extrafanart_download(json_data.get('extrafanart'), path, number, movie_path, json_data)
|
||||
else:
|
||||
extrafanart_download(json_data.get('extrafanart'), path, number, movie_path)
|
||||
|
||||
# 下载演员头像 KODI .actors 目录位置
|
||||
if conf.download_actor_photo_for_kodi():
|
||||
|
||||
Reference in New Issue
Block a user