This commit is contained in:
岛风 2024-12-22 17:45:19 +08:00
parent a6bf93ebbc
commit a604050d6c

View File

@ -49,6 +49,7 @@ class PixivSpider:
self.headers = None self.headers = None
self.current_ranking_data = [] self.current_ranking_data = []
self.failed_works = [] self.failed_works = []
self.log_messages = []
def _setup_ui(self) -> None: def _setup_ui(self) -> None:
"""设置Rich界面组件""" """设置Rich界面组件"""
@ -71,54 +72,44 @@ class PixivSpider:
TextColumn("[bold blue]{task.description}"), TextColumn("[bold blue]{task.description}"),
BarColumn(), BarColumn(),
TextColumn("{task.percentage:>3.0f}%"), TextColumn("{task.percentage:>3.0f}%"),
TextColumn("[bold green]{task.fields[speed]}"),
console=self.console, console=self.console,
expand=True, expand=True,
transient=False # 保持进度条显示 transient=False
)
# 设置日志面板 - 滚动显示在进度条上方
self.log_messages = []
self.layout["main"].update(
Panel(
Group(*self.log_messages),
title="下载状态",
border_style="green"
)
) )
# 设置进度条任务 # 设置进度条任务
self.main_task_id = self.progress.add_task( self.main_task_id = self.progress.add_task(
"总体进度", "总体进度",
total=self.TOTAL_IMAGES, total=self.TOTAL_IMAGES
speed="0.00 t / 秒"
) )
def _update_log(self, message: str) -> None: def _update_log(self, message: str, speed: float = 0.0) -> None:
"""更新日志显示""" """更新日志信息"""
# 检查是否为重复消息
if not self.log_messages or message != self.log_messages[-1]: if not self.log_messages or message != self.log_messages[-1]:
self.log_messages.append(message) self.log_messages.insert(0, message)
if len(self.log_messages) > 100: if len(self.log_messages) > 100:
self.log_messages = self.log_messages[-100:] self.log_messages = self.log_messages[:100]
try: messages = self.log_messages[:10]
# 构建消息显示,确保顺序正确
messages = self.log_messages[-30:] # 只显示最新的30条 # 清空控制台
self.console.clear()
# 重新渲染布局
self.console.print(self.layout)
# 更新日志面板 # 更新日志面板
self.layout["main"].update( log_content = "\n".join(messages)
Panel( log_panel = Panel(
Group(*messages), log_content,
title="下载状态", title="下载状态",
subtitle=f"显示最新 {len(messages)}/{len(self.log_messages)} 条消息", subtitle=f"显示最新 {len(messages)}/{len(self.log_messages)} 条消息, 速度: {speed:.2f} t/s",
border_style="green", border_style="green",
padding=(0, 1) padding=(1, 2),
expand=False
) )
) self.layout["main"].update(log_panel)
except Exception as e:
# 防止界面更新错误影响主程序
print(f"界面更新出错: {e}")
def _setup_session(self) -> None: def _setup_session(self) -> None:
"""设置请求会话""" """设置请求会话"""
@ -177,6 +168,7 @@ class PixivSpider:
# 处理排行榜页面 # 处理排行榜页面
# 保存开始时间用于计算速度 # 保存开始时间用于计算速度
start_time = time.time() start_time = time.time()
last_update_time = start_time
completed_works = 0 completed_works = 0
for page in range(1, 11): for page in range(1, 11):
@ -188,17 +180,24 @@ class PixivSpider:
else: else:
completed_works += 1 completed_works += 1
# 计算实际速度(作品/秒) # 计算实际速度(作品/秒)
elapsed_time = max(1, int(time.time() - start_time)) current_time = time.time()
speed = completed_works / elapsed_time elapsed_time = current_time - start_time
# 更新进度和速度 # 每秒更新一次速度
completed_works += 1
# 计算实际速度(作品/秒)
current_time = time.time()
elapsed_time = current_time - start_time
# 每次下载图片后更新速度
if elapsed_time > 0: # 避免除以零错误
speed = completed_works / elapsed_time
self._update_log(f"当前速度: {speed:.2f} t / s", speed)
# 更新进度
self.progress.update( self.progress.update(
self.main_task_id, self.main_task_id,
completed=completed_works, # 使用绝对值而不是增量 completed=completed_works
refresh=True, # 强制刷新显示
) )
# 单独设置速度字段
self.progress.tasks[self.main_task_id].fields["speed"] = f"{speed:.2f} t / 秒"
# 更新UI显示 # 更新UI显示
self.layout["progress"].update(self.progress) self.layout["progress"].update(self.progress)
@ -208,6 +207,6 @@ class PixivSpider:
# 清理失败作品的记录 # 清理失败作品的记录
for work_id in self.failed_works: for work_id in self.failed_works:
self.redis.client.delete(work_id) self.redis.client().delete(work_id)
self._update_log('[green]爬虫运行完成[/green]') self._update_log('[green]爬虫运行完成[/green]')