mirror of
https://github.com/LmeSzinc/StarRailCopilot.git
synced 2024-11-30 03:16:08 +00:00
151 lines
4.6 KiB
Python
151 lines
4.6 KiB
Python
import os
|
|
import re
|
|
import time
|
|
from datetime import datetime
|
|
|
|
from module.config.config import AzurLaneConfig
|
|
from module.logger import logger, pyw_name, log_file
|
|
|
|
|
|
class AzurLaneAutoScript:
|
|
def __init__(self, ini_name=''):
|
|
if not ini_name:
|
|
ini_name = pyw_name
|
|
ini_name = ini_name.lower()
|
|
self.config = AzurLaneConfig(ini_name)
|
|
|
|
def run(self, command):
|
|
try:
|
|
self.__getattribute__(command.lower())()
|
|
except Exception as e:
|
|
logger.exception(e)
|
|
|
|
if self.config.ENABLE_ERROR_LOG_AND_SCREENSHOT_SAVE:
|
|
folder = f'./log/error/{int(time.time() * 1000)}'
|
|
logger.info(f'Saving error: {folder}')
|
|
os.mkdir(folder)
|
|
for data in logger.screenshot_deque:
|
|
image_time = datetime.strftime(data['time'], '%Y-%m-%d_%H-%M-%S-%f')
|
|
data['image'].save(f'{folder}/{image_time}.png')
|
|
with open(log_file, 'r') as f:
|
|
start = 0
|
|
for index, line in enumerate(f.readlines()):
|
|
if re.search('\+-{15,}\+', line):
|
|
start = index
|
|
with open(log_file, 'r') as f:
|
|
text = f.readlines()[start - 2:]
|
|
with open(f'{folder}/log.txt', 'w') as f:
|
|
f.writelines(text)
|
|
|
|
def setting(self):
|
|
for key, value in self.config.config['Setting'].items():
|
|
print(f'{key} = {value}')
|
|
|
|
logger.hr('Settings saved')
|
|
|
|
def reward(self):
|
|
for key, value in self.config.config['Reward'].items():
|
|
print(f'{key} = {value}')
|
|
|
|
logger.hr('Reward Settings saved')
|
|
from module.reward.reward import Reward
|
|
az = Reward(self.config)
|
|
az.reward_loop()
|
|
|
|
def emulator(self):
|
|
for key, value in self.config.config['Emulator'].items():
|
|
print(f'{key} = {value}')
|
|
|
|
logger.hr('Emulator saved')
|
|
from module.handler.login import LoginHandler
|
|
az = LoginHandler(self.config)
|
|
if az.app_ensure_start():
|
|
from module.reward.reward import Reward
|
|
az = Reward(self.config)
|
|
az.reward()
|
|
|
|
def main(self):
|
|
"""
|
|
Method to run main chapter.
|
|
"""
|
|
from module.campaign.run import CampaignRun
|
|
az = CampaignRun(self.config)
|
|
az.run(self.config.CAMPAIGN_NAME)
|
|
|
|
def daily(self):
|
|
"""
|
|
Method to run daily missions.
|
|
"""
|
|
flag = True
|
|
|
|
if self.config.ENABLE_DAILY_MISSION:
|
|
from module.daily.daily import Daily
|
|
az = Daily(self.config)
|
|
if not az.record_executed_since():
|
|
az.run()
|
|
az.record_save()
|
|
flag = True
|
|
|
|
if self.config.ENABLE_HARD_CAMPAIGN:
|
|
from module.hard.hard import CampaignHard
|
|
az = CampaignHard(self.config)
|
|
if not az.record_executed_since():
|
|
az.run()
|
|
az.record_save()
|
|
flag = True
|
|
|
|
if self.config.ENABLE_EXERCISE:
|
|
from module.exercise.exercise import Exercise
|
|
az = Exercise(self.config)
|
|
if not az.record_executed_since():
|
|
az.run()
|
|
az.record_save()
|
|
flag = True
|
|
|
|
if flag:
|
|
from module.reward.reward import Reward
|
|
az = Reward(self.config)
|
|
az.reward()
|
|
|
|
def event(self):
|
|
"""
|
|
Method to run event.
|
|
"""
|
|
from module.campaign.run import CampaignRun
|
|
az = CampaignRun(self.config)
|
|
az.run(self.config.CAMPAIGN_EVENT, folder=self.config.EVENT_NAME)
|
|
|
|
def event_daily_ab(self):
|
|
from module.event.campaign_ab import CampaignAB
|
|
az = CampaignAB(self.config)
|
|
az.run_event_daily()
|
|
|
|
def semi_auto(self):
|
|
from module.daemon.daemon import AzurLaneDaemon
|
|
az = AzurLaneDaemon(self.config)
|
|
az.daemon()
|
|
|
|
def c72_mystery_farming(self):
|
|
from module.campaign.run import CampaignRun
|
|
az = CampaignRun(self.config)
|
|
az.run('campaign_7_2_mystery_farming')
|
|
|
|
def c124_leveling(self):
|
|
from module.campaign.run import CampaignRun
|
|
az = CampaignRun(self.config)
|
|
az.run('campaign_12_4_leveling')
|
|
|
|
def c122_leveling(self):
|
|
from module.campaign.run import CampaignRun
|
|
az = CampaignRun(self.config)
|
|
az.run('campaign_12_2_leveling')
|
|
|
|
def retire(self):
|
|
from module.retire.retirement import Retirement
|
|
az = Retirement(self.config)
|
|
az.retire_ships(amount=2000)
|
|
|
|
|
|
# alas = AzurLaneAutoScript()
|
|
# alas.reward()
|