to learn goupby learn pandas groupby groupby learn pandas groupby 优化正则提取番号和集数 待理解下载图片逻辑 还有剪裁+背景图逻辑 修改所有config[ 将整理生成nfo的代码 可缓存番号信息和缩略图和海报 可以识别番号后集数和尾部集数,赞不能分辨-C中文字幕片 改正一个错误 嵌套字典存储数据 整理函数 修正匹配时间正则 pipenv 添加依赖 修改优先取三位数字的规则:heyzo四位数除外 添加了依赖 和 有番号的优化 修改了啥 我也记不得了
919 lines
42 KiB
Python
Executable File
919 lines
42 KiB
Python
Executable File
# -*- coding: utf-8 -*-
|
||
|
||
import os.path
|
||
import shutil
|
||
from PIL import Image
|
||
import json
|
||
from ADC_function import *
|
||
from MediaServer import *
|
||
from AV_Data_Capture import config
|
||
import lazyxml
|
||
# =========website========
|
||
from SiteSource import avsox, javdb, fc2fans_club, javbus, fanza, mgstage
|
||
import requests
|
||
from enum import Enum, auto
|
||
|
||
|
||
# =====================本地文件处理===========================
|
||
|
||
def escapePath(path, escapeLiterals): # Remove escape literals
|
||
# escapeLiterals = Config['escape']['literals']
|
||
backslash = '\\'
|
||
for literal in escapeLiterals:
|
||
path = path.replace(backslash + literal, '')
|
||
return path
|
||
|
||
|
||
def moveFailedFolder(filepath, failed_folder):
|
||
if failed_folder.strip() == '':
|
||
print('[+]Failed output folder is Empty')
|
||
else:
|
||
print('[-]Move to Failed output folder')
|
||
shutil.move(filepath, failed_folder)
|
||
return
|
||
|
||
|
||
def CreatFailedFolder(failed_folder):
|
||
if not os.path.exists(failed_folder + '/'): # 新建failed文件夹
|
||
try:
|
||
os.makedirs(failed_folder + '/')
|
||
except:
|
||
print("[-]failed!can not be make Failed output folder\n[-](Please run as Administrator)")
|
||
return
|
||
|
||
# 根据番号获取字典数据
|
||
|
||
|
||
class SiteSource(Enum):
|
||
AVSOX = auto()
|
||
FC2 = auto()
|
||
FANZA = auto()
|
||
JAVDB = auto()
|
||
JAVBUS = auto()
|
||
MGSTAGE = auto()
|
||
|
||
|
||
def getDataFromJSON(file_number): # 从JSON返回元数据
|
||
"""
|
||
iterate through all services and fetch the data
|
||
"""
|
||
|
||
func_mapping = {
|
||
"avsox": avsox.main,
|
||
"fc2": fc2fans_club.main,
|
||
"fanza": fanza.main,
|
||
"javdb": javdb.main,
|
||
"javbus": javbus.main,
|
||
"mgstage": mgstage.main,
|
||
}
|
||
|
||
# default fetch order list, from the begining to the end
|
||
sources = ["javbus", "javdb", "fanza", "mgstage", "fc2", "avsox"]
|
||
|
||
# if the input file name matches centain rules,
|
||
# move some web service to the begining of the list
|
||
if re.match(r"^\d{5,}", file_number) or re.match(r'heyzo', file_number, re.IGNORECASE):
|
||
sources.insert(0, sources.pop(sources.index("avsox")))
|
||
elif re.match(r"\d+\D+", file_number) or re.match(r'siro', file_number, re.IGNORECASE):
|
||
sources.insert(0, sources.pop(sources.index("mgstage")))
|
||
sources.insert(0, sources.pop(sources.index("fanza")))
|
||
elif re.match(r'fc2', file_number, re.IGNORECASE):
|
||
sources.insert(0, sources.pop(sources.index("fc2")))
|
||
|
||
for source in sources:
|
||
json_data = json.loads(func_mapping[source](file_number))
|
||
# if any service return a valid return, break
|
||
if getDataState(json_data) != 0:
|
||
break
|
||
|
||
# ================================================网站规则添加结束================================================
|
||
|
||
title = json_data['title']
|
||
actor_list = str(json_data['actor']).strip("[ ]").replace("'", '').split(',') # 字符串转列表
|
||
release = json_data['release']
|
||
number = json_data['number']
|
||
studio = json_data['studio']
|
||
source = json_data['source']
|
||
runtime = json_data['runtime']
|
||
outline = json_data['runtime']
|
||
label = json_data['label']
|
||
year = json_data['year']
|
||
try:
|
||
cover_small = json_data['cover_small']
|
||
except:
|
||
cover_small = ''
|
||
|
||
imagecut = json_data['imagecut']
|
||
tag = str(json_data['tag']).strip("[ ]").replace("'", '').replace(" ", '').split(',') # 字符串转列表 @
|
||
actor = str(actor_list).strip("[ ]").replace("'", '').replace(" ", '')
|
||
|
||
if title == '' or number == '':
|
||
raise Exception('[-]Movie Data not found!')
|
||
|
||
# if imagecut == '3':
|
||
# DownloadFileWithFilename()
|
||
|
||
# ====================处理异常字符====================== #\/:*?"<>|
|
||
title = re.sub(r'[#\\/:*?"<>|\]]', '', title, 0, re.IGNORECASE)
|
||
release = release.replace('/', '-')
|
||
tmpArr = cover_small.split(',')
|
||
if len(tmpArr) > 0:
|
||
cover_small = tmpArr[0].strip('\"').strip('\'')
|
||
# ====================处理异常字符 END================== #\/:*?"<>|
|
||
|
||
naming_rule = eval(config.naming_rule)
|
||
location_rule = eval(config.location_rule)
|
||
|
||
# 返回处理后的json_data
|
||
json_data['title'] = title
|
||
json_data['actor'] = actor
|
||
json_data['release'] = release
|
||
json_data['cover_small'] = cover_small
|
||
json_data['tag'] = tag
|
||
json_data['naming_rule'] = naming_rule
|
||
json_data['location_rule'] = location_rule
|
||
json_data['year'] = year
|
||
return json_data
|
||
|
||
|
||
def get_info(json_data): # 返回json里的数据
|
||
title = json_data['title']
|
||
studio = json_data['studio']
|
||
year = json_data['year']
|
||
outline = json_data['outline']
|
||
runtime = json_data['runtime']
|
||
director = json_data['director']
|
||
actor_photo = json_data['actor_photo']
|
||
release = json_data['release']
|
||
number = json_data['number']
|
||
cover = json_data['cover']
|
||
website = json_data['website']
|
||
return title, studio, year, outline, runtime, director, actor_photo, release, number, cover, website
|
||
|
||
|
||
def download_cover_file(url, name, folder_path):
|
||
"""
|
||
download small cover
|
||
:param url: url
|
||
:param name: name same as movie's name without ext
|
||
:param folder_path: dir to save
|
||
:return:
|
||
"""
|
||
filename = config.media_server.poster_name(name)
|
||
DownloadFileWithFilename(url, filename, folder_path)
|
||
|
||
|
||
def smallCoverCheck(path, number, imagecut, cover_small, c_word, option, filepath, failed_folder):
|
||
if imagecut == 3:
|
||
if option == 'emby':
|
||
DownloadFileWithFilename(cover_small, '1.jpg', path, filepath, failed_folder)
|
||
try:
|
||
img = Image.open(path + '/1.jpg')
|
||
except Exception:
|
||
img = Image.open('1.jpg')
|
||
w = img.width
|
||
h = img.height
|
||
img.save(path + '/' + number + c_word + '.png')
|
||
time.sleep(1)
|
||
os.remove(path + '/1.jpg')
|
||
if option == 'kodi':
|
||
DownloadFileWithFilename(cover_small, '1.jpg', path, filepath, failed_folder)
|
||
try:
|
||
img = Image.open(path + '/1.jpg')
|
||
except Exception:
|
||
img = Image.open('1.jpg')
|
||
w = img.width
|
||
h = img.height
|
||
img.save(path + '/' + number + c_word + '-poster.jpg')
|
||
time.sleep(1)
|
||
os.remove(path + '/1.jpg')
|
||
if option == 'plex':
|
||
DownloadFileWithFilename(cover_small, '1.jpg', path, filepath, failed_folder)
|
||
try:
|
||
img = Image.open(path + '/1.jpg')
|
||
except Exception:
|
||
img = Image.open('1.jpg')
|
||
w = img.width
|
||
h = img.height
|
||
img.save(path + '/poster.jpg')
|
||
os.remove(path + '/1.jpg')
|
||
|
||
|
||
def creatFolder(success_folder, location_rule, json_data, escapeLiterals): # 创建文件夹
|
||
title, studio, year, outline, runtime, director, actor_photo, release, number, cover, website = get_info(json_data)
|
||
if len(location_rule) > 240: # 新建成功输出文件夹
|
||
path = success_folder + '/' + location_rule.replace("'actor'", "'manypeople'", 3).replace("actor",
|
||
"'manypeople'",
|
||
3) # path为影片+元数据所在目录
|
||
else:
|
||
path = success_folder + '/' + location_rule
|
||
# print(path)
|
||
if not os.path.exists(path):
|
||
path = escapePath(path, escapeLiterals)
|
||
try:
|
||
os.makedirs(path)
|
||
except:
|
||
path = success_folder + '/' + location_rule.replace('/[' + number + ']-' + title, "/number")
|
||
path = escapePath(path, escapeLiterals)
|
||
os.makedirs(path)
|
||
return path
|
||
|
||
|
||
# =====================资源下载部分===========================
|
||
def download_file(url, folder, name_with_ext):
|
||
"""
|
||
download file
|
||
:param url: source url
|
||
:param name_with_ext: full name like 'mike.jpg'
|
||
:param folder: folder path
|
||
:return: full path if downloaded file like '/Users/proj/AV_Data_Capture/mike.jpg'
|
||
"""
|
||
proxy_dict = {"http": str(config.proxy), "https": str(config.proxy)} if config.proxy else None
|
||
i = 0
|
||
while i < config.retry:
|
||
try:
|
||
if not os.path.exists(folder):
|
||
os.makedirs(folder)
|
||
headers = {
|
||
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.106 Safari/537.36'}
|
||
r = requests.get(url, headers=headers, timeout=config.timeout, proxies=proxy_dict)
|
||
if r == '':
|
||
print('[-]Movie Data not found!')
|
||
return
|
||
with open(str(folder) + "/" + name_with_ext, "wb") as code:
|
||
code.write(r.content)
|
||
return str(folder) + "/" + name_with_ext
|
||
except requests.exceptions.RequestException:
|
||
i += 1
|
||
print('[-]Image Download : Connect retry ' + str(i) + '/' + str(config.retry))
|
||
except requests.exceptions.ConnectionError:
|
||
i += 1
|
||
print('[-]Image Download : Connect retry ' + str(i) + '/' + str(config.retry))
|
||
except requests.exceptions.ProxyError:
|
||
i += 1
|
||
print('[-]Image Download : Connect retry ' + str(i) + '/' + str(config.retry))
|
||
except requests.exceptions.ConnectTimeout:
|
||
i += 1
|
||
print('[-]Image Download : Connect retry ' + str(i) + '/' + str(config.retry))
|
||
|
||
|
||
def DownloadFileWithFilename(url, filename, path): # path = examle:photo , video.in the Project Folder!
|
||
proxy, timeout, retry_count = get_network_settings()
|
||
i = 0
|
||
proxy_dict = {"http": str(config.proxy), "https": str(config.proxy)} if proxy else None
|
||
while i < retry_count:
|
||
try:
|
||
if not os.path.exists(path):
|
||
os.makedirs(path)
|
||
headers = {
|
||
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.106 Safari/537.36'}
|
||
r = requests.get(url, headers=headers, timeout=timeout,
|
||
proxies=proxy_dict)
|
||
if r == '':
|
||
print('[-]Movie Data not found!')
|
||
return
|
||
with open(str(path) + "/" + filename, "wb") as code:
|
||
code.write(r.content)
|
||
return
|
||
except requests.exceptions.RequestException:
|
||
i += 1
|
||
print('[-]Image Download : Connect retry ' + str(i) + '/' + str(retry_count))
|
||
except requests.exceptions.ConnectionError:
|
||
i += 1
|
||
print('[-]Image Download : Connect retry ' + str(i) + '/' + str(retry_count))
|
||
except requests.exceptions.ProxyError:
|
||
i += 1
|
||
print('[-]Image Download : Connect retry ' + str(i) + '/' + str(retry_count))
|
||
except requests.exceptions.ConnectTimeout:
|
||
i += 1
|
||
print('[-]Image Download : Connect retry ' + str(i) + '/' + str(retry_count))
|
||
print('[-]Connect Failed! Please check your Proxy or Network!')
|
||
# moveFailedFolder(filepath, failed_folder)
|
||
return
|
||
|
||
|
||
def download_image(url, name, folder):
|
||
"""
|
||
download img
|
||
:param url: source
|
||
:param name: name
|
||
:param folder: folder to save
|
||
:return:
|
||
"""
|
||
name_with_ext = config.media_server.image_name(name)
|
||
download_file(url, folder, name_with_ext)
|
||
|
||
|
||
def imageDownload(option, cover, number, c_word, path, multi_part, filepath, failed_folder): # 封面是否下载成功,否则移动到failed
|
||
if option == 'emby': # name.jpg
|
||
if DownloadFileWithFilename(cover, number + c_word + '.jpg', path, filepath, failed_folder) == 'failed':
|
||
moveFailedFolder(filepath, failed_folder)
|
||
return
|
||
DownloadFileWithFilename(cover, number + c_word + '.jpg', path, filepath, failed_folder)
|
||
if not os.path.getsize(path + '/' + number + c_word + '.jpg') == 0:
|
||
print('[+]Image Downloaded!', path + '/' + number + c_word + '.jpg')
|
||
return
|
||
i = 1
|
||
while i <= int(config.retry):
|
||
if os.path.getsize(path + '/' + number + c_word + '.jpg') == 0:
|
||
print('[!]Image Download Failed! Trying again. [' + config.retry + '/3]')
|
||
DownloadFileWithFilename(cover, number + c_word + '.jpg', path, filepath, failed_folder)
|
||
i = i + 1
|
||
continue
|
||
else:
|
||
break
|
||
if multi_part == 1:
|
||
old_name = os.path.join(path, number + c_word + '.jpg')
|
||
new_name = os.path.join(path, number + c_word + '.jpg')
|
||
os.rename(old_name, new_name)
|
||
print('[+]Image Downloaded!', path + '/' + number + c_word + '.jpg')
|
||
else:
|
||
print('[+]Image Downloaded!', path + '/' + number + c_word + '.jpg')
|
||
elif option == 'plex': # fanart.jpg
|
||
if DownloadFileWithFilename(cover, 'fanart.jpg', path, filepath, failed_folder) == 'failed':
|
||
moveFailedFolder(filepath, failed_folder)
|
||
return
|
||
DownloadFileWithFilename(cover, 'fanart.jpg', path, filepath, failed_folder)
|
||
if not os.path.getsize(path + '/fanart.jpg') == 0:
|
||
print('[+]Image Downloaded!', path + '/fanart.jpg')
|
||
return
|
||
i = 1
|
||
while i <= int(config.retry):
|
||
if os.path.getsize(path + '/fanart.jpg') == 0:
|
||
print('[!]Image Download Failed! Trying again. [' + config.retry + '/3]')
|
||
DownloadFileWithFilename(cover, 'fanart.jpg', path, filepath, failed_folder)
|
||
i = i + 1
|
||
continue
|
||
else:
|
||
break
|
||
if not os.path.getsize(path + '/' + number + c_word + '.jpg') == 0:
|
||
print('[!]Image Download Failed! Trying again.')
|
||
DownloadFileWithFilename(cover, number + c_word + '.jpg', path, filepath, failed_folder)
|
||
print('[+]Image Downloaded!', path + '/fanart.jpg')
|
||
elif option == 'kodi': # [name]-fanart.jpg
|
||
if DownloadFileWithFilename(cover, number + c_word + '-fanart.jpg', path, filepath, failed_folder) == 'failed':
|
||
moveFailedFolder(filepath, failed_folder)
|
||
return
|
||
DownloadFileWithFilename(cover, number + c_word + '-fanart.jpg', path, filepath, failed_folder)
|
||
if not os.path.getsize(path + '/' + number + c_word + '-fanart.jpg') == 0:
|
||
print('[+]Image Downloaded!', path + '/' + number + c_word + '-fanart.jpg')
|
||
return
|
||
i = 1
|
||
while i <= int(config.retry):
|
||
if os.path.getsize(path + '/' + number + c_word + '-fanart.jpg') == 0:
|
||
print('[!]Image Download Failed! Trying again. [' + config.retry + '/3]')
|
||
DownloadFileWithFilename(cover, number + c_word + '-fanart.jpg', path, filepath, failed_folder)
|
||
i = i + 1
|
||
continue
|
||
else:
|
||
break
|
||
print('[+]Image Downloaded!', path + '/' + number + c_word + '-fanart.jpg')
|
||
|
||
|
||
def make_nfo_file(nfo, nfo_name, folder_path):
|
||
"""
|
||
make xxx.nfo in folder
|
||
:param nfo_name: name
|
||
:param nfo: nfo dict
|
||
:param folder_path: where to create file, default temp_folder
|
||
:return:
|
||
"""
|
||
title, studio, year, outline, runtime, director, actor_photo, release, number, cover, website = get_info(nfo)
|
||
naming_rule = nfo['naming_rule']
|
||
tag = nfo['tag']
|
||
|
||
path = folder_path
|
||
c_word = ''
|
||
cn_sub = ''
|
||
part = ''
|
||
# path_file = path + "/" + number + c_word + ".nfo", "wt"
|
||
path_file = path + "/" + nfo_name + c_word + ".nfo"
|
||
lazyxml.dump
|
||
try:
|
||
if not os.path.exists(path):
|
||
os.makedirs(path)
|
||
if config.media_server == MediaServer.PLEX:
|
||
with open(path_file, "wt", encoding='UTF-8') as code:
|
||
print('<?xml version="1.0" encoding="UTF-8" ?>', file=code)
|
||
print("<movie>", file=code)
|
||
print(" <title>" + naming_rule + part + "</title>", file=code)
|
||
print(" <set>", file=code)
|
||
print(" </set>", file=code)
|
||
print(" <studio>" + studio + "+</studio>", file=code)
|
||
print(" <year>" + year + "</year>", file=code)
|
||
print(" <outline>" + outline + "</outline>", file=code)
|
||
print(" <plot>" + outline + "</plot>", file=code)
|
||
print(" <runtime>" + str(runtime).replace(" ", "") + "</runtime>", file=code)
|
||
print(" <director>" + director + "</director>", file=code)
|
||
print(" <poster>poster.jpg</poster>", file=code)
|
||
print(" <thumb>thumb.png</thumb>", file=code)
|
||
print(" <fanart>fanart.jpg</fanart>", file=code)
|
||
try:
|
||
for key, value in actor_photo.items():
|
||
print(" <actor>", file=code)
|
||
print(" <name>" + key + "</name>", file=code)
|
||
if not value == '': # or actor_photo == []:
|
||
print(" <thumb>" + value + "</thumb>", file=code)
|
||
print(" </actor>", file=code)
|
||
except:
|
||
aaaa = ''
|
||
print(" <maker>" + studio + "</maker>", file=code)
|
||
print(" <label>", file=code)
|
||
print(" </label>", file=code)
|
||
if cn_sub == '1':
|
||
print(" <tag>中文字幕</tag>", file=code)
|
||
try:
|
||
for i in str(tag).strip("[ ]").replace("'", '').replace(" ", '').split(','):
|
||
print(" <tag>" + i + "</tag>", file=code)
|
||
except:
|
||
aaaaa = ''
|
||
try:
|
||
for i in str(tag).strip("[ ]").replace("'", '').replace(" ", '').split(','):
|
||
print(" <genre>" + i + "</genre>", file=code)
|
||
except:
|
||
aaaaaaaa = ''
|
||
if cn_sub == '1':
|
||
print(" <genre>中文字幕</genre>", file=code)
|
||
print(" <num>" + number + "</num>", file=code)
|
||
print(" <release>" + release + "</release>", file=code)
|
||
print(" <cover>" + cover + "</cover>", file=code)
|
||
print(" <website>" + website + "</website>", file=code)
|
||
print("</movie>", file=code)
|
||
print("[+]Writeed! " + path + "/" + number + ".nfo")
|
||
elif config.media_server == MediaServer.EMBY:
|
||
with open(path_file, "wt", encoding='UTF-8') as code:
|
||
print('<?xml version="1.0" encoding="UTF-8" ?>', file=code)
|
||
print("<movie>", file=code)
|
||
print(" <title>" + naming_rule + part + "</title>", file=code)
|
||
print(" <set>", file=code)
|
||
print(" </set>", file=code)
|
||
print(" <studio>" + studio + "+</studio>", file=code)
|
||
print(" <year>" + year + "</year>", file=code)
|
||
print(" <outline>" + outline + "</outline>", file=code)
|
||
print(" <plot>" + outline + "</plot>", file=code)
|
||
print(" <runtime>" + str(runtime).replace(" ", "") + "</runtime>", file=code)
|
||
print(" <director>" + director + "</director>", file=code)
|
||
print(" <poster>" + number + c_word + ".png</poster>", file=code)
|
||
print(" <thumb>" + number + c_word + ".png</thumb>", file=code)
|
||
print(" <fanart>" + number + c_word + '.jpg' + "</fanart>", file=code)
|
||
try:
|
||
for key, value in actor_photo.items():
|
||
print(" <actor>", file=code)
|
||
print(" <name>" + key + "</name>", file=code)
|
||
if not value == '': # or actor_photo == []:
|
||
print(" <thumb>" + value + "</thumb>", file=code)
|
||
print(" </actor>", file=code)
|
||
except:
|
||
aaaa = ''
|
||
print(" <maker>" + studio + "</maker>", file=code)
|
||
print(" <label>", file=code)
|
||
print(" </label>", file=code)
|
||
if cn_sub == '1':
|
||
print(" <tag>中文字幕</tag>", file=code)
|
||
try:
|
||
for i in tag:
|
||
print(" <tag>" + i + "</tag>", file=code)
|
||
except:
|
||
aaaaa = ''
|
||
try:
|
||
for i in tag:
|
||
print(" <genre>" + i + "</genre>", file=code)
|
||
except:
|
||
aaaaaaaa = ''
|
||
if cn_sub == '1':
|
||
print(" <genre>中文字幕</genre>", file=code)
|
||
print(" <num>" + number + "</num>", file=code)
|
||
print(" <premiered>" + release + "</premiered>", file=code)
|
||
print(" <cover>" + cover + "</cover>", file=code)
|
||
print(" <website>" + website + "</website>", file=code)
|
||
print("</movie>", file=code)
|
||
print("[+]Writeed! " + path + "/" + number + c_word + ".nfo")
|
||
elif config.media_server == MediaServer.KODI:
|
||
with open(path_file, "wt", encoding='UTF-8') as code:
|
||
print('<?xml version="1.0" encoding="UTF-8" ?>', file=code)
|
||
print("<movie>", file=code)
|
||
print(" <title>" + naming_rule + part + "</title>", file=code)
|
||
print(" <set>", file=code)
|
||
print(" </set>", file=code)
|
||
print(" <studio>" + studio + "+</studio>", file=code)
|
||
print(" <year>" + year + "</year>", file=code)
|
||
print(" <outline>" + outline + "</outline>", file=code)
|
||
print(" <plot>" + outline + "</plot>", file=code)
|
||
print(" <runtime>" + str(runtime).replace(" ", "") + "</runtime>", file=code)
|
||
print(" <director>" + director + "</director>", file=code)
|
||
print(" <poster>" + number + c_word + "-poster.jpg</poster>", file=code)
|
||
print(" <fanart>" + number + c_word + '-fanart.jpg' + "</fanart>", file=code)
|
||
try:
|
||
for key, value in actor_photo.items():
|
||
print(" <actor>", file=code)
|
||
print(" <name>" + key + "</name>", file=code)
|
||
if not value == '': # or actor_photo == []:
|
||
print(" <thumb>" + value + "</thumb>", file=code)
|
||
print(" </actor>", file=code)
|
||
except:
|
||
aaaa = ''
|
||
print(" <maker>" + studio + "</maker>", file=code)
|
||
print(" <label>", file=code)
|
||
print(" </label>", file=code)
|
||
if cn_sub == '1':
|
||
print(" <tag>中文字幕</tag>", file=code)
|
||
try:
|
||
for i in tag:
|
||
print(" <tag>" + i + "</tag>", file=code)
|
||
except:
|
||
aaaaa = ''
|
||
try:
|
||
for i in tag:
|
||
print(" <genre>" + i + "</genre>", file=code)
|
||
except:
|
||
aaaaaaaa = ''
|
||
if cn_sub == '1':
|
||
print(" <genre>中文字幕</genre>", file=code)
|
||
print(" <num>" + number + "</num>", file=code)
|
||
print(" <release>" + release + "</release>", file=code)
|
||
print(" <cover>" + cover + "</cover>", file=code)
|
||
print(" <website>" + website + "</website>", file=code)
|
||
print("</movie>", file=code)
|
||
print("[+]Writeed! " + path + "/" + number + c_word + ".nfo")
|
||
except IOError as e:
|
||
print("[-]Write Failed! :" + e)
|
||
# print(e)
|
||
# moveFailedFolder(filepath, failed_folder)
|
||
return
|
||
except Exception as e:
|
||
print("[-]Write Failed! :" + e)
|
||
# moveFailedFolder(filepath, failed_folder)
|
||
return
|
||
|
||
|
||
def PrintFiles(option, path, c_word, naming_rule, part, cn_sub, json_data, filepath, failed_folder, tag):
|
||
title, studio, year, outline, runtime, director, actor_photo, release, number, cover, website = get_info(json_data)
|
||
try:
|
||
if not os.path.exists(path):
|
||
os.makedirs(path)
|
||
if option == 'plex':
|
||
with open(path + "/" + number + c_word + ".nfo", "wt", encoding='UTF-8') as code:
|
||
print('<?xml version="1.0" encoding="UTF-8" ?>', file=code)
|
||
print("<movie>", file=code)
|
||
print(" <title>" + naming_rule + part + "</title>", file=code)
|
||
print(" <set>", file=code)
|
||
print(" </set>", file=code)
|
||
print(" <studio>" + studio + "+</studio>", file=code)
|
||
print(" <year>" + year + "</year>", file=code)
|
||
print(" <outline>" + outline + "</outline>", file=code)
|
||
print(" <plot>" + outline + "</plot>", file=code)
|
||
print(" <runtime>" + str(runtime).replace(" ", "") + "</runtime>", file=code)
|
||
print(" <director>" + director + "</director>", file=code)
|
||
print(" <poster>poster.jpg</poster>", file=code)
|
||
print(" <thumb>thumb.png</thumb>", file=code)
|
||
print(" <fanart>fanart.jpg</fanart>", file=code)
|
||
try:
|
||
for key, value in actor_photo.items():
|
||
print(" <actor>", file=code)
|
||
print(" <name>" + key + "</name>", file=code)
|
||
if not value == '': # or actor_photo == []:
|
||
print(" <thumb>" + value + "</thumb>", file=code)
|
||
print(" </actor>", file=code)
|
||
except:
|
||
aaaa = ''
|
||
print(" <maker>" + studio + "</maker>", file=code)
|
||
print(" <label>", file=code)
|
||
print(" </label>", file=code)
|
||
if cn_sub == '1':
|
||
print(" <tag>中文字幕</tag>", file=code)
|
||
try:
|
||
for i in str(json_data['tag']).strip("[ ]").replace("'", '').replace(" ", '').split(','):
|
||
print(" <tag>" + i + "</tag>", file=code)
|
||
except:
|
||
aaaaa = ''
|
||
try:
|
||
for i in str(json_data['tag']).strip("[ ]").replace("'", '').replace(" ", '').split(','):
|
||
print(" <genre>" + i + "</genre>", file=code)
|
||
except:
|
||
aaaaaaaa = ''
|
||
if cn_sub == '1':
|
||
print(" <genre>中文字幕</genre>", file=code)
|
||
print(" <num>" + number + "</num>", file=code)
|
||
print(" <release>" + release + "</release>", file=code)
|
||
print(" <cover>" + cover + "</cover>", file=code)
|
||
print(" <website>" + website + "</website>", file=code)
|
||
print("</movie>", file=code)
|
||
print("[+]Writeed! " + path + "/" + number + ".nfo")
|
||
elif option == 'emby':
|
||
with open(path + "/" + number + c_word + ".nfo", "wt", encoding='UTF-8') as code:
|
||
print('<?xml version="1.0" encoding="UTF-8" ?>', file=code)
|
||
print("<movie>", file=code)
|
||
print(" <title>" + naming_rule + part + "</title>", file=code)
|
||
print(" <set>", file=code)
|
||
print(" </set>", file=code)
|
||
print(" <studio>" + studio + "+</studio>", file=code)
|
||
print(" <year>" + year + "</year>", file=code)
|
||
print(" <outline>" + outline + "</outline>", file=code)
|
||
print(" <plot>" + outline + "</plot>", file=code)
|
||
print(" <runtime>" + str(runtime).replace(" ", "") + "</runtime>", file=code)
|
||
print(" <director>" + director + "</director>", file=code)
|
||
print(" <poster>" + number + c_word + ".png</poster>", file=code)
|
||
print(" <thumb>" + number + c_word + ".png</thumb>", file=code)
|
||
print(" <fanart>" + number + c_word + '.jpg' + "</fanart>", file=code)
|
||
try:
|
||
for key, value in actor_photo.items():
|
||
print(" <actor>", file=code)
|
||
print(" <name>" + key + "</name>", file=code)
|
||
if not value == '': # or actor_photo == []:
|
||
print(" <thumb>" + value + "</thumb>", file=code)
|
||
print(" </actor>", file=code)
|
||
except:
|
||
aaaa = ''
|
||
print(" <maker>" + studio + "</maker>", file=code)
|
||
print(" <label>", file=code)
|
||
print(" </label>", file=code)
|
||
if cn_sub == '1':
|
||
print(" <tag>中文字幕</tag>", file=code)
|
||
try:
|
||
for i in tag:
|
||
print(" <tag>" + i + "</tag>", file=code)
|
||
except:
|
||
aaaaa = ''
|
||
try:
|
||
for i in tag:
|
||
print(" <genre>" + i + "</genre>", file=code)
|
||
except:
|
||
aaaaaaaa = ''
|
||
if cn_sub == '1':
|
||
print(" <genre>中文字幕</genre>", file=code)
|
||
print(" <num>" + number + "</num>", file=code)
|
||
print(" <premiered>" + release + "</premiered>", file=code)
|
||
print(" <cover>" + cover + "</cover>", file=code)
|
||
print(" <website>" + website + "</website>", file=code)
|
||
print("</movie>", file=code)
|
||
print("[+]Writeed! " + path + "/" + number + c_word + ".nfo")
|
||
elif option == 'kodi':
|
||
with open(path + "/" + number + c_word + ".nfo", "wt", encoding='UTF-8') as code:
|
||
print('<?xml version="1.0" encoding="UTF-8" ?>', file=code)
|
||
print("<movie>", file=code)
|
||
print(" <title>" + naming_rule + part + "</title>", file=code)
|
||
print(" <set>", file=code)
|
||
print(" </set>", file=code)
|
||
print(" <studio>" + studio + "+</studio>", file=code)
|
||
print(" <year>" + year + "</year>", file=code)
|
||
print(" <outline>" + outline + "</outline>", file=code)
|
||
print(" <plot>" + outline + "</plot>", file=code)
|
||
print(" <runtime>" + str(runtime).replace(" ", "") + "</runtime>", file=code)
|
||
print(" <director>" + director + "</director>", file=code)
|
||
print(" <poster>" + number + c_word + "-poster.jpg</poster>", file=code)
|
||
print(" <fanart>" + number + c_word + '-fanart.jpg' + "</fanart>", file=code)
|
||
try:
|
||
for key, value in actor_photo.items():
|
||
print(" <actor>", file=code)
|
||
print(" <name>" + key + "</name>", file=code)
|
||
if not value == '': # or actor_photo == []:
|
||
print(" <thumb>" + value + "</thumb>", file=code)
|
||
print(" </actor>", file=code)
|
||
except:
|
||
aaaa = ''
|
||
print(" <maker>" + studio + "</maker>", file=code)
|
||
print(" <label>", file=code)
|
||
print(" </label>", file=code)
|
||
if cn_sub == '1':
|
||
print(" <tag>中文字幕</tag>", file=code)
|
||
try:
|
||
for i in tag:
|
||
print(" <tag>" + i + "</tag>", file=code)
|
||
except:
|
||
aaaaa = ''
|
||
try:
|
||
for i in tag:
|
||
print(" <genre>" + i + "</genre>", file=code)
|
||
except:
|
||
aaaaaaaa = ''
|
||
if cn_sub == '1':
|
||
print(" <genre>中文字幕</genre>", file=code)
|
||
print(" <num>" + number + "</num>", file=code)
|
||
print(" <release>" + release + "</release>", file=code)
|
||
print(" <cover>" + cover + "</cover>", file=code)
|
||
print(" <website>" + website + "</website>", file=code)
|
||
print("</movie>", file=code)
|
||
print("[+]Writeed! " + path + "/" + number + c_word + ".nfo")
|
||
except IOError as e:
|
||
print("[-]Write Failed!")
|
||
print(e)
|
||
moveFailedFolder(filepath, failed_folder)
|
||
return
|
||
except Exception as e1:
|
||
print(e1)
|
||
print("[-]Write Failed!")
|
||
moveFailedFolder(filepath, failed_folder)
|
||
return
|
||
|
||
|
||
def crop_image(crop_style, name, path):
|
||
try:
|
||
origin_image = Image.open(path + '/' + config.media_server.image_name(name))
|
||
if crop_style == 1:
|
||
cropped_image = origin_image.crop((origin_image.width / 1.9, 0, origin_image.width, origin_image.height))
|
||
else:
|
||
cropped_image = origin_image
|
||
cropped_image.save(path + '/' + config.media_server.poster_name(name))
|
||
|
||
except Exception as e:
|
||
print('[-]Cover cut failed:' + e)
|
||
|
||
|
||
def cutImage(option, imagecut, path, number, c_word):
|
||
if option == 'plex':
|
||
if imagecut == 1: # 截取右侧封面 fanart.jpg 截取为poster.jpg
|
||
try:
|
||
img = Image.open(path + '/fanart.jpg')
|
||
imgSize = img.size
|
||
w = img.width
|
||
h = img.height
|
||
img2 = img.crop((w / 1.9, 0, w, h))
|
||
img2.save(path + '/poster.jpg')
|
||
except:
|
||
print('[-]Cover cut failed!')
|
||
elif imagecut == 0: # 改名 fanart.jpg ->poster.jpg
|
||
img = Image.open(path + '/fanart.jpg')
|
||
w = img.width
|
||
h = img.height
|
||
img.save(path + '/poster.jpg')
|
||
elif option == 'emby':
|
||
if imagecut == 1: # 截取右侧封面 [name].jpg 截取为 [name].jpg
|
||
try:
|
||
img = Image.open(path + '/' + number + c_word + '.jpg')
|
||
imgSize = img.size
|
||
w = img.width
|
||
h = img.height
|
||
img2 = img.crop((w / 1.9, 0, w, h))
|
||
img2.save(path + '/' + number + c_word + '.png')
|
||
except:
|
||
print('[-]Cover cut failed!')
|
||
elif imagecut == 0: # [name].jpg -> [name].png
|
||
img = Image.open(path + '/' + number + c_word + '.jpg')
|
||
img.save(path + '/' + number + c_word + '.png')
|
||
elif option == 'kodi':
|
||
if imagecut == 1: # 截取右侧封面 [name]-fanart.jpg 截取为 [name]-poster.jpg
|
||
try:
|
||
img = Image.open(path + '/' + number + c_word + '-fanart.jpg')
|
||
w = img.width
|
||
h = img.height
|
||
img2 = img.crop((w / 1.9, 0, w, h))
|
||
img2.save(path + '/' + number + c_word + '-poster.jpg')
|
||
except:
|
||
print('[-]Cover cut failed!')
|
||
elif imagecut == 0: # [name]-fanart.jpg 截取为 [name]-poster.jpg
|
||
img = Image.open(path + '/' + number + c_word + '-fanart.jpg')
|
||
|
||
try:
|
||
img = img.convert('RGB')
|
||
img.save(path + '/' + number + c_word + '-poster.jpg')
|
||
except:
|
||
img = img.convert('RGB')
|
||
img.save(path + '/' + number + c_word + '-poster.jpg')
|
||
|
||
|
||
def pasteFileToFolder(filepath, path, number, c_word): # 文件路径,番号,后缀,要移动至的位置
|
||
houzhui = str(re.search('[.](avi|rmvb|wmv|mov|mp4|mkv|flv|ts|webm)$', filepath, re.IGNORECASE).group())
|
||
try:
|
||
if config.soft_link == '1': # 如果soft_link=1 使用软链接
|
||
os.symlink(filepath, path + '/' + number + c_word + houzhui)
|
||
else:
|
||
os.rename(filepath, path + '/' + number + c_word + houzhui)
|
||
if os.path.exists(config.search_folder + '/' + number + c_word + '.srt'): # 字幕移动
|
||
os.rename(config.search_folder + '/' + number + c_word + '.srt', path + '/' + number + c_word + '.srt')
|
||
print('[+]Sub moved!')
|
||
elif os.path.exists(config.search_folder + '/' + number + c_word + '.ssa'):
|
||
os.rename(os.getcwd() + '/' + number + c_word + '.ssa', path + '/' + number + c_word + '.ssa')
|
||
print('[+]Sub moved!')
|
||
elif os.path.exists(config.search_folder + '/' + number + c_word + '.sub'):
|
||
os.rename(os.getcwd() + '/' + number + c_word + '.sub', path + '/' + number + c_word + '.sub')
|
||
print('[+]Sub moved!')
|
||
except FileExistsError:
|
||
print('[-]File Exists! Please check your movie!')
|
||
print('[-]move to the root folder of the program.')
|
||
return
|
||
except PermissionError:
|
||
print('[-]Error! Please run as administrator!')
|
||
return
|
||
|
||
|
||
def pasteFileToFolder_mode2(filepath, path, multi_part, number, part, c_word): # 文件路径,番号,后缀,要移动至的位置
|
||
if multi_part == 1:
|
||
number += part # 这时number会被附加上CD1后缀
|
||
houzhui = str(re.search('[.](avi|rmvb|wmv|mov|mp4|mkv|flv|ts|webm)$', filepath, re.IGNORECASE).group())
|
||
try:
|
||
if config.soft_link== '1':
|
||
os.symlink(filepath, path + '/' + number + part + c_word + houzhui)
|
||
else:
|
||
os.rename(filepath, path + '/' + number + part + c_word + houzhui)
|
||
if os.path.exists(number + '.srt'): # 字幕移动
|
||
os.rename(number + part + c_word + '.srt', path + '/' + number + part + c_word + '.srt')
|
||
print('[+]Sub moved!')
|
||
elif os.path.exists(number + part + c_word + '.ass'):
|
||
os.rename(number + part + c_word + '.ass', path + '/' + number + part + c_word + '.ass')
|
||
print('[+]Sub moved!')
|
||
elif os.path.exists(number + part + c_word + '.sub'):
|
||
os.rename(number + part + c_word + '.sub', path + '/' + number + part + c_word + '.sub')
|
||
print('[+]Sub moved!')
|
||
print('[!]Success')
|
||
except FileExistsError:
|
||
print('[-]File Exists! Please check your movie!')
|
||
print('[-]move to the root folder of the program.')
|
||
return
|
||
except PermissionError:
|
||
print('[-]Error! Please run as administrator!')
|
||
return
|
||
|
||
|
||
def copy_images_to_background_image(name, path):
|
||
shutil.copy(path + "/" + config.media_server.image_name(name), path + "/Backdrop.jpg")
|
||
if config.media_server == MediaServer.PLEX:
|
||
shutil.copy(path + "/" + config.media_server.poster_name(name), path + '/thumb.png')
|
||
|
||
|
||
def copyRenameJpgToBackdrop(option, path, number, c_word):
|
||
if option == 'plex':
|
||
shutil.copy(path + '/fanart.jpg', path + '/Backdrop.jpg')
|
||
shutil.copy(path + '/poster.jpg', path + '/thumb.png')
|
||
if option == 'emby':
|
||
shutil.copy(path + '/' + number + c_word + '.jpg', path + '/Backdrop.jpg')
|
||
if option == 'kodi':
|
||
shutil.copy(path + '/' + number + c_word + '-fanart.jpg', path + '/Backdrop.jpg')
|
||
|
||
|
||
def get_part(filepath, failed_folder):
|
||
try:
|
||
if re.search('-CD\d+', filepath):
|
||
return re.findall('-CD\d+', filepath)[0]
|
||
if re.search('-cd\d+', filepath):
|
||
return re.findall('-cd\d+', filepath)[0]
|
||
except:
|
||
print("[-]failed!Please rename the filename again!")
|
||
moveFailedFolder(filepath, failed_folder)
|
||
return
|
||
|
||
|
||
def debug_mode(json_data):
|
||
try:
|
||
if config.debug_mode == '1':
|
||
print('[+] ---Debug info---')
|
||
for i, v in json_data.items():
|
||
if i == 'outline':
|
||
print('[+] -', i, ' :', len(v), 'characters')
|
||
continue
|
||
if i == 'actor_photo' or i == 'year':
|
||
continue
|
||
print('[+] -', "%-11s" % i, ':', v)
|
||
print('[+] ---Debug info---')
|
||
except:
|
||
aaa = ''
|
||
|
||
|
||
def core_main(number_th):
|
||
# =======================================================================初始化所需变量
|
||
multi_part = 0
|
||
part = ''
|
||
c_word = ''
|
||
option = ''
|
||
cn_sub = ''
|
||
|
||
# filepath = file_path # 影片的路径
|
||
number = number_th
|
||
|
||
json_data = getDataFromJSON(number) # 定义番号
|
||
|
||
# if json_data.get('number') != number:
|
||
# fix issue #119
|
||
# the root cause is we normalize the search id
|
||
# PrintFiles() will use the normalized id from website,
|
||
# but pasteFileToFolder() still use the input raw search id
|
||
# so the solution is: use the normalized search id
|
||
# number = json_data["number"]
|
||
# imagecut = json_data['imagecut']
|
||
# tag = json_data['tag']
|
||
# =======================================================================判断-C,-CD后缀
|
||
# if '-CD' in filepath or '-cd' in filepath:
|
||
# multi_part = 1
|
||
# part = get_part(filepath, config.failed_folder)
|
||
|
||
# if '-c.' in filepath or '-C.' in filepath or '中文' in filepath or '字幕' in filepath:
|
||
# cn_sub = '1'
|
||
# c_word = '-C' # 中文字幕影片后缀
|
||
|
||
# CreatFailedFolder(config.failed_folder) # 创建输出失败目录
|
||
# debug_mode(json_data) # 调试模式检测
|
||
return json_data
|
||
# path = creatFolder(config.success_folder, json_data['location_rule'], json_data, config.escape_literals) # 创建文件夹
|
||
# =======================================================================刮削模式
|
||
# if config.program_mode == '1':
|
||
# if multi_part == 1:
|
||
# number += part # 这时number会被附加上CD1后缀
|
||
# smallCoverCheck(path, number, imagecut, json_data['cover_small'], c_word, option, filepath, config.failed_folder) # 检查小封面
|
||
# imageDownload(option, json_data['cover'], number, c_word, path, multi_part, filepath, config.failed_folder) # creatFoder会返回番号路径
|
||
# cutImage(option, imagecut, path, number, c_word) # 裁剪图
|
||
# copyRenameJpgToBackdrop(option, path, number, c_word)
|
||
# PrintFiles(option, path, c_word, json_data['naming_rule'], part, cn_sub, json_data, filepath, config.failed_folder, tag) # 打印文件 .nfo
|
||
# pasteFileToFolder(filepath, path, number, c_word) # 移动文件
|
||
# # =======================================================================整理模式
|
||
# elif config.program_mode == '2':
|
||
# pasteFileToFolder_mode2(filepath, path, multi_part, number, part, c_word) # 移动文件
|