AV_Data_Capture/ADC_function.py
Tan Peng fc13f88731 优化正则等,修改逻辑,避免被覆盖
to learn goupby

learn pandas groupby

groupby

learn pandas groupby

优化正则提取番号和集数

待理解下载图片逻辑

还有剪裁+背景图逻辑

修改所有config[

将整理生成nfo的代码

可缓存番号信息和缩略图和海报

可以识别番号后集数和尾部集数,赞不能分辨-C中文字幕片

改正一个错误

嵌套字典存储数据

整理函数

修正匹配时间正则

pipenv 添加依赖

修改优先取三位数字的规则:heyzo四位数除外

添加了依赖 和 有番号的优化

修改了啥 我也记不得了
2022-10-09 20:47:38 +08:00

128 lines
4.2 KiB
Python
Executable File

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import requests
from configparser import ConfigParser
import os
import re
import time
import sys
from lxml import etree
import sys
import io
from ConfigApp import ConfigApp
# sys.stdout = io.TextIOWrapper(sys.stdout.buffer, errors = 'replace', line_buffering = True)
# sys.setdefaultencoding('utf-8')
# config_file='config.ini'
# config = ConfigParser()
# if os.path.exists(config_file):
# try:
# config.read(config_file, encoding='UTF-8')
# except:
# print('[-]Config.ini read failed! Please use the offical file!')
# else:
# print('[+]config.ini: not found, creating...',end='')
# with open("config.ini", "wt", encoding='UTF-8') as code:
# print("[common]", file=code)
# print("main_mode = 1", file=code)
# print("failed_output_folder = failed", file=code)
# print("success_output_folder = JAV_output", file=code)
# print("", file=code)
# print("[proxy]",file=code)
# print("proxy=127.0.0.1:1081",file=code)
# print("timeout=10", file=code)
# print("retry=3", file=code)
# print("", file=code)
# print("[Name_Rule]", file=code)
# print("location_rule=actor+'/'+number",file=code)
# print("naming_rule=number+'-'+title",file=code)
# print("", file=code)
# print("[update]",file=code)
# print("update_check=1",file=code)
# print("", file=code)
# print("[media]", file=code)
# print("media_warehouse=emby", file=code)
# print("#emby plex kodi", file=code)
# print("", file=code)
# print("[escape]", file=code)
# print("literals=\\", file=code)
# print("", file=code)
# print("[movie_location]", file=code)
# print("path=", file=code)
# print("", file=code)
# print('.',end='')
# time.sleep(2)
# print('.')
# print('[+]config.ini: created!')
# print('[+]Please restart the program!')
# time.sleep(4)
# os._exit(0)
# try:
# config.read(config_file, encoding='UTF-8')
# except:
# print('[-]Config.ini read failed! Please use the offical file!')
config = ConfigApp()
def get_network_settings():
try:
proxy = config.proxy
timeout = int(config.timeout)
retry_count = int(config.retry)
assert timeout > 0
assert retry_count > 0
except:
raise ValueError("[-]Proxy config error! Please check the config.")
return proxy, timeout, retry_count
def getDataState(json_data): # 元数据获取失败检测
if json_data['title'] == '' or json_data['title'] == 'None' or json_data['title'] == 'null':
return 0
else:
return 1
def ReadMediaWarehouse():
return config.media_server
def UpdateCheckSwitch():
check=str(config.update_check)
if check == '1':
return '1'
elif check == '0':
return '0'
elif check == '':
return '0'
def getXpathSingle(htmlcode,xpath):
html = etree.fromstring(htmlcode, etree.HTMLParser())
result1 = str(html.xpath(xpath)).strip(" ['']")
return result1
def get_html(url,cookies = None):#网页请求核心
proxy, timeout, retry_count = get_network_settings()
i = 0
print(url)
while i < retry_count:
try:
if not proxy == '':
proxies = {"http": proxy, "https": proxy}
headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3100.0 Safari/537.36'}
getweb = requests.get(str(url), headers=headers, timeout=timeout, proxies=proxies, cookies=cookies)
getweb.encoding = 'utf-8'
return getweb.text
else:
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'}
getweb = requests.get(str(url), headers=headers, timeout=timeout, cookies=cookies)
getweb.encoding = 'utf-8'
return getweb.text
except Exception as e:
print(e)
i += 1
print('[-]Connect retry '+str(i)+'/'+str(retry_count))
print('[-]Connect Failed! Please check your Proxy or Network!')