2025-04-30 06:14:41 +00:00
|
|
|
|
# coding=utf-8
|
|
|
|
|
|
"""
|
|
|
|
|
|
@project: maxkb
|
|
|
|
|
|
@Author:虎
|
|
|
|
|
|
@file: html_split_handle.py
|
|
|
|
|
|
@date:2024/5/23 10:58
|
|
|
|
|
|
@desc:
|
|
|
|
|
|
"""
|
|
|
|
|
|
import re
|
|
|
|
|
|
import traceback
|
|
|
|
|
|
from typing import List
|
|
|
|
|
|
|
|
|
|
|
|
from bs4 import BeautifulSoup
|
|
|
|
|
|
from charset_normalizer import detect
|
|
|
|
|
|
from html2text import html2text
|
|
|
|
|
|
|
|
|
|
|
|
from common.handle.base_split_handle import BaseSplitHandle
|
2025-06-30 04:40:11 +00:00
|
|
|
|
from common.utils.logger import maxkb_logger
|
2025-04-30 06:14:41 +00:00
|
|
|
|
from common.utils.split_model import SplitModel
|
|
|
|
|
|
|
|
|
|
|
|
default_pattern_list = [re.compile('(?<=^)# .*|(?<=\\n)# .*'),
|
|
|
|
|
|
re.compile('(?<=\\n)(?<!#)## (?!#).*|(?<=^)(?<!#)## (?!#).*'),
|
|
|
|
|
|
re.compile("(?<=\\n)(?<!#)### (?!#).*|(?<=^)(?<!#)### (?!#).*"),
|
|
|
|
|
|
re.compile("(?<=\\n)(?<!#)#### (?!#).*|(?<=^)(?<!#)#### (?!#).*"),
|
|
|
|
|
|
re.compile("(?<=\\n)(?<!#)##### (?!#).*|(?<=^)(?<!#)##### (?!#).*"),
|
|
|
|
|
|
re.compile("(?<=\\n)(?<!#)###### (?!#).*|(?<=^)(?<!#)###### (?!#).*")]
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def get_encoding(buffer):
|
|
|
|
|
|
beautiful_soup = BeautifulSoup(buffer, "html.parser")
|
|
|
|
|
|
meta_list = beautiful_soup.find_all('meta')
|
|
|
|
|
|
charset_list = [meta.attrs.get('charset') for meta in meta_list if
|
|
|
|
|
|
meta.attrs is not None and 'charset' in meta.attrs]
|
|
|
|
|
|
if len(charset_list) > 0:
|
|
|
|
|
|
charset = charset_list[0]
|
|
|
|
|
|
return charset
|
|
|
|
|
|
return detect(buffer)['encoding']
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class HTMLSplitHandle(BaseSplitHandle):
|
|
|
|
|
|
def support(self, file, get_buffer):
|
|
|
|
|
|
file_name: str = file.name.lower()
|
|
|
|
|
|
if file_name.endswith(".html") or file_name.endswith(".HTML"):
|
|
|
|
|
|
return True
|
|
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
|
|
|
def handle(self, file, pattern_list: List, with_filter: bool, limit: int, get_buffer, save_image):
|
|
|
|
|
|
buffer = get_buffer(file)
|
2025-06-30 04:49:50 +00:00
|
|
|
|
if type(limit) is str:
|
|
|
|
|
|
limit = int(limit)
|
2025-07-10 07:06:10 +00:00
|
|
|
|
if type(with_filter) is str:
|
|
|
|
|
|
with_filter = with_filter.lower() == 'true'
|
2025-04-30 06:14:41 +00:00
|
|
|
|
if pattern_list is not None and len(pattern_list) > 0:
|
|
|
|
|
|
split_model = SplitModel(pattern_list, with_filter, limit)
|
|
|
|
|
|
else:
|
|
|
|
|
|
split_model = SplitModel(default_pattern_list, with_filter=with_filter, limit=limit)
|
|
|
|
|
|
try:
|
|
|
|
|
|
encoding = get_encoding(buffer)
|
|
|
|
|
|
content = buffer.decode(encoding)
|
|
|
|
|
|
content = html2text(content)
|
|
|
|
|
|
except BaseException as e:
|
2025-06-30 04:40:11 +00:00
|
|
|
|
maxkb_logger.error(f"Error processing HTML file {file.name}: {e}, {traceback.format_exc()}")
|
|
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
|
'name': file.name, 'content': []
|
|
|
|
|
|
}
|
|
|
|
|
|
return {
|
|
|
|
|
|
'name': file.name,
|
|
|
|
|
|
'content': split_model.parse(content)
|
|
|
|
|
|
}
|
2025-04-30 06:14:41 +00:00
|
|
|
|
|
|
|
|
|
|
def get_content(self, file, save_image):
|
|
|
|
|
|
buffer = file.read()
|
|
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
|
encoding = get_encoding(buffer)
|
|
|
|
|
|
content = buffer.decode(encoding)
|
|
|
|
|
|
return html2text(content)
|
|
|
|
|
|
except BaseException as e:
|
|
|
|
|
|
traceback.print_exception(e)
|
2025-04-30 08:06:30 +00:00
|
|
|
|
return f'{e}'
|