-
Notifications
You must be signed in to change notification settings - Fork 18
/
generate.py
140 lines (117 loc) · 4.5 KB
/
generate.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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
import os
import json
import base64
from datetime import datetime
from urllib.parse import urlparse
import shutil
from zipfile import ZipFile
def get_netloc(url):
"""
传入一个url获取完整的子域名
"""
return urlparse(url).netloc if url else ''
def merge_json_files(folder_path):
"""
将指定文件夹下的json文件合并为一个字典
"""
indexers = {}
for filename in os.listdir(folder_path):
if not filename.endswith(".json"):
continue
filepath = os.path.join(folder_path, filename)
try:
with open(filepath, "r", encoding="utf-8") as f:
data = json.load(f)
if not isinstance(data, dict) or not data.get("domain"):
continue
netloc = get_netloc(data["domain"])
indexers[netloc] = data
except Exception as e:
print(f"Error reading {filename}: {str(e)}")
return indexers
def save_data_to_json(data, json_path, json_pack_path):
"""
将数据保存为两个不同格式的json文件
"""
version = datetime.now().strftime("%Y%m%d%H%M")
result = {"version": version, "indexer": data}
with open(json_path, "w", encoding="utf-8") as f:
json.dump(result, f, ensure_ascii=True, indent=4)
with open(json_pack_path, "w", encoding="utf-8") as f:
json.dump(result, f, separators=(',', ':'), ensure_ascii=True)
def save_json_to_dat(json_path, bin_path):
"""
将json文件转换为base64并保存到dat文件
"""
with open(json_path, "r", encoding="utf-8") as f:
json_data = f.read()
base64_data = base64.b64encode(json_data.encode("utf-8")).decode("utf-8")
with open(bin_path, "w", encoding="utf-8") as f:
f.write(base64_data)
def format_json_file(file_path):
"""
格式化json文件
"""
try:
with open(file_path, "r") as f:
data = json.load(f)
except json.JSONDecodeError as e:
print(f"Error decoding JSON in {file_path}: {e}")
return
with open(file_path, "w") as f:
json.dump(data, f, indent=4)
def format_json_files_in_folder(folder_path):
"""
格式化指定文件夹下的所有json文件
"""
for filename in os.listdir(folder_path):
file_path = os.path.join(folder_path, filename)
if os.path.isfile(file_path) and filename.lower().endswith(".json"):
format_json_file(file_path)
def create_or_clear_sites_file(sites_dat_path):
"""
创建或清空文件
"""
mode = "w" if os.path.exists(sites_dat_path) else "x"
with open(sites_dat_path, mode):
pass
def compress_folder(folder_path, output_zip_name):
"""
压缩指定文件夹并保存到当前目录下
"""
if os.path.exists(output_zip_name):
os.remove(output_zip_name)
with ZipFile(output_zip_name, 'w') as zipf:
for root, dirs, files in os.walk(folder_path):
for file in files:
file_path = os.path.join(root, file)
zipf.write(file_path, os.path.relpath(file_path, folder_path))
def gather_json_files(input_folder, output_file_path, url_prefix):
if os.path.exists(output_file_path):
os.remove(output_file_path)
for filename in os.listdir(input_folder):
if not filename.endswith(".json"):
continue
json_file_path = os.path.join(input_folder, filename)
with open(output_file_path, 'a', encoding='utf-8') as output_file:
output_file.write(f"{url_prefix}/{json_file_path}\n")
def extract_archive(archive_path, output_folder):
"""
解压缩指定的压缩包到指定的文件夹
"""
shutil.unpack_archive(archive_path, output_folder)
if __name__ == "__main__":
# 格式化sites目录下的json文件
format_json_files_in_folder("sites")
# 创建或清空相关文件
for file_path in ["user.sites.bin", "user.sites.json", "user.sites.pack.json"]:
create_or_clear_sites_file(file_path)
# 合并json文件并保存为不同格式
indexers = merge_json_files("sites")
save_data_to_json(indexers, "user.sites.json", "user.sites.pack.json")
# 将json文件转为dat文件
save_json_to_dat("user.sites.pack.json", "user.sites.bin")
# 将sites目录压缩后保存
compress_folder("sites", "user.sites.jsons.zip")
# 写入所有的json文件地址到文件中
gather_json_files("sites", "user.sites.jsons.txt", "https://raw.githubusercontent.com/hsuyelin/nas-tools-sites/master")