-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathachievements.py
92 lines (72 loc) · 2.67 KB
/
achievements.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
"""
Achievements data extractor
src:
achievements.xlsx https://docs.qq.com/sheet/DS01hbnZwZm5KVnBB?tab=BB08J2
achievements.py https://github.com/KimigaiiWuyi/GenshinUID/blob/main/GenshinUID/tools/get_achievement_json.py
"""
import json
import warnings
from pathlib import Path
from typing import List
from openpyxl import Workbook, load_workbook
from openpyxl.worksheet.worksheet import Worksheet
from pydantic import BaseModel
warnings.filterwarnings('ignore', category=UserWarning, module='openpyxl')
import_path = "src/achievements.xlsx"
export_path = Path("Resources")
wb: Workbook = load_workbook(import_path)
ws_daily: Worksheet = wb['成就相关每日委托']
ws_all: Worksheet = wb['正式服成就汇总']
result_daily = []
result_all = []
class BaseAchievement(BaseModel):
name: str
desc: str
guide: str
link: str
class Achievement(BaseAchievement):
book: str
class TaskAchievement(BaseAchievement):
task: List[str]
def load_daily_achievements():
is_first = False
for row in range(3, 100):
ach = TaskAchievement(
task=[],
name=ws_daily.cell(row, 4).value or "",
desc=ws_daily.cell(row, 5).value or "",
guide=ws_daily.cell(row, 6).value or "",
link=ws_daily.cell(row, 6).hyperlink.target if ws_daily.cell(row, 6).hyperlink else '',
)
task = ws_daily.cell(row, 3).value or ""
if not task:
if is_first:
break
is_first = True
continue
else:
is_first = False
ach.task = [i for i in task.split('\n') if not i.startswith('(')]
result_daily.append(ach.dict())
def load_all_achievements(book: Worksheet, loop: int, bn: int, an: int, dn: int, gn: int):
for row in range(3, loop):
ach = Achievement(
book=book.cell(row, bn).value or "",
name=book.cell(row, an).value or "",
desc=book.cell(row, dn).value or "",
guide=book.cell(row, gn).value or "",
link=book.cell(row, gn).hyperlink.target if book.cell(row, gn).hyperlink else '',
)
if not ach.book:
break
result_all.append(ach.dict())
def save_achievements():
export_path.mkdir(parents=True, exist_ok=True)
with open(export_path / 'achievements_daily.json', 'w', encoding='utf-8') as f:
json.dump(result_daily, f, indent=4, ensure_ascii=False)
with open(export_path / 'achievements_all.json', 'w', encoding='utf-8') as f:
json.dump(result_all, f, indent=4, ensure_ascii=False)
if __name__ == '__main__':
load_all_achievements(ws_all, 1000, 5, 6, 7, 11)
load_daily_achievements()
save_achievements()