2021-05-25 13:30:53 +00:00
|
|
|
|
import os
|
2021-05-27 13:25:58 +00:00
|
|
|
|
import sys
|
2021-05-25 13:30:53 +00:00
|
|
|
|
import main
|
|
|
|
|
import time
|
2022-01-09 09:31:44 +00:00
|
|
|
|
import push
|
2021-05-25 13:30:53 +00:00
|
|
|
|
import config
|
2021-06-06 09:50:00 +00:00
|
|
|
|
import random
|
2021-05-26 10:11:27 +00:00
|
|
|
|
import setting
|
2022-01-06 05:49:25 +00:00
|
|
|
|
from loghelper import log
|
|
|
|
|
from error import CookieError
|
2021-05-25 13:30:53 +00:00
|
|
|
|
|
2021-10-25 14:53:34 +00:00
|
|
|
|
|
|
|
|
|
# 搜索配置文件
|
2022-01-06 05:49:25 +00:00
|
|
|
|
def fund_config() -> list:
|
|
|
|
|
file_name = []
|
2021-05-25 13:30:53 +00:00
|
|
|
|
for files in os.listdir(config.path):
|
|
|
|
|
if os.path.splitext(files)[1] == '.json':
|
2022-01-06 05:49:25 +00:00
|
|
|
|
file_name.append(files)
|
|
|
|
|
return file_name
|
2021-05-25 13:30:53 +00:00
|
|
|
|
|
2021-10-25 14:53:34 +00:00
|
|
|
|
|
|
|
|
|
def main_multi(autorun: bool):
|
2022-01-06 05:49:25 +00:00
|
|
|
|
log.info("AutoMihoyoBBS Multi User mode")
|
|
|
|
|
log.info("正在搜索配置文件!")
|
|
|
|
|
config_list = fund_config()
|
|
|
|
|
if len(config_list) == 0:
|
|
|
|
|
log.warning("未检测到配置文件,请确认config文件夹存在.json后缀名的配置文件!")
|
2021-08-03 02:58:32 +00:00
|
|
|
|
exit(1)
|
2021-06-13 02:33:38 +00:00
|
|
|
|
if autorun:
|
2022-01-06 05:49:25 +00:00
|
|
|
|
log.info(f"已搜索到{len(config_list)}个配置文件,正在开始执行!")
|
2021-05-29 01:34:21 +00:00
|
|
|
|
else:
|
2022-01-06 05:49:25 +00:00
|
|
|
|
log.info(f"已搜索到{len(config_list)}个配置文件,请确认是否无多余文件!\r\n{config_list}")
|
2021-05-30 04:27:16 +00:00
|
|
|
|
try:
|
|
|
|
|
input("请输入回车继续,需要重新搜索配置文件请Ctrl+C退出脚本")
|
|
|
|
|
except:
|
2021-08-03 02:58:32 +00:00
|
|
|
|
exit(0)
|
2022-01-09 07:25:47 +00:00
|
|
|
|
results = {"ok": [], "close": [], "error": []}
|
2022-01-06 05:49:25 +00:00
|
|
|
|
for i in iter(config_list):
|
|
|
|
|
log.info(f"正在执行{i}")
|
2021-05-26 10:11:27 +00:00
|
|
|
|
setting.mihoyobbs_List_Use = []
|
2021-10-25 14:53:34 +00:00
|
|
|
|
config.config_Path = f"{config.path}/{i}"
|
2022-01-06 03:27:24 +00:00
|
|
|
|
try:
|
2022-01-09 07:25:47 +00:00
|
|
|
|
run_code = main.main()
|
2022-01-06 05:49:25 +00:00
|
|
|
|
except CookieError:
|
2022-01-06 03:27:24 +00:00
|
|
|
|
results["error"].append(i)
|
|
|
|
|
else:
|
2022-01-09 07:25:47 +00:00
|
|
|
|
if run_code == 0:
|
|
|
|
|
results["ok"].append(i)
|
|
|
|
|
else:
|
|
|
|
|
results["close"].append(i)
|
2022-01-06 05:49:25 +00:00
|
|
|
|
log.info(f"{i}执行完毕")
|
2021-07-17 03:07:38 +00:00
|
|
|
|
time.sleep(random.randint(3, 10))
|
2022-01-06 05:58:38 +00:00
|
|
|
|
print("")
|
2022-01-09 11:15:50 +00:00
|
|
|
|
push_message = f'脚本执行完毕,共执行{len(config_list)}个配置文件,成功{len(results["ok"])}个,没执行{len(results["close"])}个,失败{len(results["error"])}个'\
|
2022-01-10 01:57:57 +00:00
|
|
|
|
f'\r\n没执行的脚本: {results["close"]}\r\n执行失败的脚本: {results["error"]}'
|
2022-01-09 09:31:44 +00:00
|
|
|
|
log.info(push_message)
|
|
|
|
|
push.push(0,push_message)
|
2021-05-25 13:30:53 +00:00
|
|
|
|
|
2021-10-25 14:53:34 +00:00
|
|
|
|
|
2021-05-25 13:30:53 +00:00
|
|
|
|
if __name__ == "__main__":
|
2021-12-04 13:55:50 +00:00
|
|
|
|
if (len(sys.argv) >= 2 and sys.argv[1] == "autorun") or os.getenv("AutoMihoyoBBS_autorun") == "1":
|
2021-06-13 02:33:38 +00:00
|
|
|
|
autorun = True
|
|
|
|
|
else:
|
|
|
|
|
autorun = False
|
|
|
|
|
main_multi(autorun)
|
2021-08-03 02:58:32 +00:00
|
|
|
|
exit(0)
|
2021-10-25 14:53:34 +00:00
|
|
|
|
pass
|