forked from phantom-sea-limited/Crawler
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsangtacviet.py
89 lines (78 loc) · 2.71 KB
/
sangtacviet.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
# coding=utf-8
import re
import sys
import json
from Lib.Epub import Epub
def remove_html_tags(text):
"匹配并剔除除了 <img> 标签之外的所有 HTML 标签"
pattern = r'<(?!img\b)[^>]*>'
clean_text = re.sub(pattern, '', text)
return clean_text
def remove_all_html_tags(text):
clean = re.compile('<.*?>')
return re.sub(clean, '', text).replace(" ", "")
def find_src(k):
try:
return re.findall(r'''<img referrerpolicy="no-referrer" src="([\s\S]+?)">''', k)[0]
except:
print(f"[WARNING]:\t failed using Default regular expression \t {k}")
try:
return re.findall(r'''<img alt="([\s\S]+?)" src="([\s\S]+?)"''', k)[0][1]
except:
print(f"[WARNING]:\t failed using Senior regular expression \t {k}")
try:
tmp = re.findall(r'''src="([\s\S]+?)"''', k)[0]
print(f"[WARNING]:\t using Unsafety regular expression \t {k}")
return tmp
except:
print(
f"[Critical]:\t can not find the src with all regular expression \t {k}")
if len(sys.argv) != 2:
print("缺失json文件")
else:
file = sys.argv[1]
with open(file, "r", encoding="utf-8") as f:
raw = json.load(f)
e = Epub(describe={
"name": raw["bookname"],
"author": raw["author"],
"update_time": raw["book_uptime"],
"coverurl": raw["cover"],
"describe": raw["details"].split("\n")
})
i = 1
while i < len(raw["chapterList"]):
Chaptername = raw["chapterList"][i]["name"]
for j in raw["chapterList"][i]["lists"]:
chap = raw["chapterList"][i]["lists"][j]
content = remove_html_tags(chap["content"]).split("\n")
text = [{
"Uid": chap["href"].split("/")[-2],
"title": f'{Chaptername}-{chap["name"]}',
"lines": []
}]
for k in content:
k = k.replace('\u3000', " ")
if "<img" not in k:
text[0]['lines'].append({
"type": "p",
"item": k
})
else:
text[0]['lines'].append(
{
"type": "img",
"item": find_src(k)
}
)
k = remove_all_html_tags(k) # 部分跟在图片后的文本,影响不大
if k != "":
text[0]['lines'].append(
{
"type": "p",
"item": k
}
)
e.add_text(text)
i += 1
e.finish()