优化代码逻辑 修复bug

This commit is contained in:
LibraHp_0928 2024-09-28 11:09:08 +08:00
parent 7d32579838
commit dd59d2d54c

80
main.py
View File

@ -191,6 +191,7 @@ def save_image(url,file_name):
except Exception as e: except Exception as e:
log(e,"error") log(e,"error")
class PaginatedContainer(ft.Column): class PaginatedContainer(ft.Column):
def __init__(self, data, items_per_page=5, title="Title"): def __init__(self, data, items_per_page=5, title="Title"):
super().__init__() super().__init__()
@ -217,6 +218,7 @@ class PaginatedContainer(ft.Column):
def build(self): def build(self):
# 导出组件 # 导出组件
export_control = ft.PopupMenuButton( export_control = ft.PopupMenuButton(
icon=ft.icons.SEND_AND_ARCHIVE,
items=[ items=[
ft.PopupMenuItem(text="导出为JSON", on_click=self.export_json), ft.PopupMenuItem(text="导出为JSON", on_click=self.export_json),
ft.PopupMenuItem(text="导出为Excel", on_click=self.export_excel), ft.PopupMenuItem(text="导出为Excel", on_click=self.export_excel),
@ -235,7 +237,13 @@ class PaginatedContainer(ft.Column):
ft.Row( ft.Row(
controls=[ controls=[
ft.Text(self.title, size=20, weight="bold"), ft.Text(self.title, size=20, weight="bold"),
export_control ft.Row(
controls=[
ft.Text("导出为"),
export_control
]
)
], ],
alignment=ft.MainAxisAlignment.SPACE_BETWEEN alignment=ft.MainAxisAlignment.SPACE_BETWEEN
), ),
@ -300,9 +308,12 @@ class PaginatedContainer(ft.Column):
# 将数据转换为 JSON 字符串 # 将数据转换为 JSON 字符串
json_string = json.dumps(json_data, ensure_ascii=False, indent=4) json_string = json.dumps(json_data, ensure_ascii=False, indent=4)
# 写入到文件 # 写入到文件
with open(f"{save_path}/{now_login_user.uin}_{self.title}_data.json", "w", encoding="utf-8") as f: try:
f.write(json_string) with open(f"{save_path}/{now_login_user.uin}_{self.title}_data.json", "w", encoding="utf-8") as f:
log(f"导出成功 请查看 {now_login_user.uin}_{self.title}_data.json","success") f.write(json_string)
log(f"导出成功 请查看 {now_login_user.uin}_{self.title}_data.json","success")
except Exception as e:
log(e,"error")
def export_excel(self,e): def export_excel(self,e):
@ -325,12 +336,14 @@ class PaginatedContainer(ft.Column):
'Images': item.images if item.images else '', 'Images': item.images if item.images else '',
'Comment': item.comment.content if item.comment else '', 'Comment': item.comment.content if item.comment else '',
}) })
try:
# 将数据转换为 DataFrame # 将数据转换为 DataFrame
df = pd.DataFrame(export_data) df = pd.DataFrame(export_data)
# 保存为 Excel 文件 # 保存为 Excel 文件
df.to_excel(f"{save_path}/{now_login_user.uin}_{self.title}_data.xlsx", index=False) df.to_excel(f"{save_path}/{now_login_user.uin}_{self.title}_data.xlsx", index=False)
log(f"导出成功 请查看 {now_login_user.uin}_{self.title}_data.xlsx","success") log(f"导出成功 请查看 {now_login_user.uin}_{self.title}_data.xlsx","success")
except Exception as e:
log(e,"error")
def export_html(self, e): def export_html(self, e):
@ -460,11 +473,13 @@ class PaginatedContainer(ft.Column):
# 保存 HTML 文件 # 保存 HTML 文件
file_name = f"{now_login_user.uin}_{self.title}_data.html" file_name = f"{now_login_user.uin}_{self.title}_data.html"
file_path = f"{save_path}/{file_name}" file_path = f"{save_path}/{file_name}"
with open(file_path, 'w', encoding='utf-8') as f: try:
f.write(html_content) with open(file_path, 'w', encoding='utf-8') as f:
f.write(html_content)
# 日志记录 # 日志记录
log(f"导出成功 请查看 {file_name}", "success") log(f"导出成功 请查看 {file_name}", "success")
except Exception as e:
log(f"导出失败 {e}", "error")
@ -497,15 +512,20 @@ class PaginatedContainer(ft.Column):
# 生成 Markdown 内容 # 生成 Markdown 内容
markdown_content = "\n".join(markdown_lines) markdown_content = "\n".join(markdown_lines)
try:
with open(f"{save_path}/{now_login_user.uin}_{self.title}_data.md", 'w', encoding='utf-8') as f:
f.write(markdown_content)
log(f"导出成功 请查看 {now_login_user.uin}_{self.title}_data.md","success")
except Exception as e:
log(e,"error")
with open(f"{save_path}/{now_login_user.uin}_{self.title}_data.md", 'w', encoding='utf-8') as f:
f.write(markdown_content)
log(f"导出成功 请查看 {now_login_user.uin}_{self.title}_data.md","success")
def did_mount(self): def did_mount(self):
"""This method is called when the control is added to the page.""" """This method is called when the control is added to the page."""
self.update_page_info() self.update_page_info()
def update_page_info(self): def update_page_info(self):
# 更新当前页的内容 # 更新当前页的内容
self.load_page_data() self.load_page_data()
@ -673,7 +693,7 @@ def main(page: ft.Page):
page.vertical_alignment = "center" page.vertical_alignment = "center"
page.window.resizable = False page.window.resizable = False
page.padding = ft.padding.only(20,20,20,5) page.padding = ft.padding.only(20,20,20,5)
page.bgcolor = "#f0f0f0" # page.bgcolor = "#f0f0f0"
# page.window.icon = "https://picsum.photos/200" # page.window.icon = "https://picsum.photos/200"
# 字体使用系统默认字体 # 字体使用系统默认字体
page.theme= ft.Theme(font_family="Microsoft YaHei") page.theme= ft.Theme(font_family="Microsoft YaHei")
@ -869,7 +889,7 @@ def main(page: ft.Page):
create_card_list_view(progress_bar, login_text) create_card_list_view(progress_bar, login_text)
# p_skey = requests.utils.dict_from_cookiejar(r.cookies).get('p_skey') # p_skey = requests.utils.dict_from_cookiejar(r.cookies).get('p_skey')
except Exception as e: except Exception as e:
log(e,"error") log("登录失败 请检查网络环境是否正常","error")
except Exception as e: except Exception as e:
log(e,"error") log(e,"error")
@ -977,7 +997,7 @@ def main(page: ft.Page):
def get_hitokoto(): def get_hitokoto():
url = "https://v1.hitokoto.cn/" url = "https://v1.hitokoto.cn/"
response = requests.get(url) response = requests.get(url,headers=headers)
if response.status_code == 200: if response.status_code == 200:
data = response.json() data = response.json()
@ -1124,7 +1144,7 @@ def main(page: ft.Page):
), ),
padding=10, padding=10,
border_radius=ft.border_radius.all(5), border_radius=ft.border_radius.all(5),
bgcolor=ft.colors.GREY_100, # bgcolor=ft.colors.GREY_100,
expand=True, expand=True,
), ),
ft.Text(f"一言: {hitokoto}\n出自: {source}", size=14) ft.Text(f"一言: {hitokoto}\n出自: {source}", size=14)
@ -1212,7 +1232,7 @@ def main(page: ft.Page):
ft.ElevatedButton("退出当前账号登录", on_click=change_route, data="Logout", width=200), ft.ElevatedButton("退出当前账号登录", on_click=change_route, data="Logout", width=200),
ft.TextButton("Powered by LibraHp", url="https://github.com/LibraHp", data="Github", width=200) ft.TextButton("Powered by LibraHp", url="https://github.com/LibraHp", data="Github", width=200)
], ],
alignment="start", alignment="center",
spacing=10 spacing=10
) )
@ -1221,11 +1241,12 @@ def main(page: ft.Page):
content=ft.Column( content=ft.Column(
controls=[user_info, tabs], controls=[user_info, tabs],
spacing=20, spacing=20,
horizontal_alignment="start", horizontal_alignment="center",
scroll=ft.ScrollMode.HIDDEN, scroll=ft.ScrollMode.HIDDEN,
), ),
width=220, alignment=ft.alignment.center,
bgcolor="#ffffff", col=2,
# bgcolor="#ffffff",
border_radius=10, border_radius=10,
padding=10 padding=10
) )
@ -1248,14 +1269,15 @@ def main(page: ft.Page):
expand=True, expand=True,
scroll=ft.ScrollMode.HIDDEN scroll=ft.ScrollMode.HIDDEN
), ),
bgcolor="#ffffff", # bgcolor="#ffffff",
expand=True, expand=True,
padding=20, padding=20,
border_radius=10 border_radius=10,
col=10
) )
# 主布局 # 主布局
main_layout = ft.Row( main_layout = ft.ResponsiveRow(
controls=[left_panel, content_area], controls=[left_panel, content_area],
expand=True, expand=True,
alignment="start" alignment="start"