mirror of
https://github.com/LibraHp/GetQzonehistory.git
synced 2025-01-04 03:09:09 +00:00
优化代码逻辑 修复bug
This commit is contained in:
parent
7d32579838
commit
dd59d2d54c
80
main.py
80
main.py
@ -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"
|
||||||
|
Loading…
Reference in New Issue
Block a user