python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > Python网站网页管理

基于Python实现网站网页管理小工具

作者:学习&实践爱好者

这篇文章主要为大家详细介绍了如何基于Python实现一个网站网页管理小工具,主要用途是帮助用户整理,存储和快速访问常用网站信息,感兴趣的小伙伴可以了解下

前言

这个程序是一个网站/网页管理工具,主要用途是帮助用户整理、存储和快速访问常用网站信息,具体功能包括:

适合需要管理多个常用网站(如学习平台、工作工具、常用服务等)的用户,相当于一个个性化的 “网站收藏夹”,比浏览器自带收藏夹更灵活(可添加自定义备注)。

特别说明:第一次运行时,由于websites.json不存在,会自动加载预设的默认网站数据。当新增、编辑、删除网站,会于当前目录下建立本地文件:websites.json。之后就会加载使用websites.json的数据。

本程序需要的模块tkinter、webbrowser、json、os是 Python 默认包含的基础库,安装 Python 时已自动附带,无需额外安装。

运行界面

完整源码

import tkinter as tk
from tkinter import ttk, messagebox   #, scrolledtext
import webbrowser
import json
import os

class WebsiteManager:
    def __init__(self, root):
        self.root = root
        self.root.title("网站管理器")
        self.root.geometry("900x600")  # 增加宽度以容纳备注列
        
        # 存储网站数据
        self.websites = []
        
        # 加载保存的数据
        self.load_data()
        
        # 创建界面
        self.create_widgets()
        
    def create_widgets(self):
        # 顶部标题
        title_label = tk.Label(self.root, text="网站 管理器", font=("Arial", 16, "bold"))
        title_label.pack(pady=10)
        
        # 允许编辑复选框
        self.edit_var = tk.BooleanVar()
        self.edit_check = tk.Checkbutton(self.root, text="允许编辑", variable=self.edit_var, 
                                        command=self.toggle_editing)
        self.edit_check.pack(anchor="w", padx=20)
        
        # 输入区域框架
        input_frame = tk.Frame(self.root)
        input_frame.pack(fill="x", padx=20, pady=10)
        
        # 网站名称
        tk.Label(input_frame, text="网站名称:").grid(row=0, column=0, sticky="w", pady=5)
        self.name_entry = tk.Entry(input_frame, width=42)
        self.name_entry.grid(row=0, column=1, sticky="w", pady=5, padx=5)
        
        # URL
        tk.Label(input_frame, text="URL:").grid(row=1, column=0, sticky="w", pady=5)
        self.url_entry = tk.Entry(input_frame, width=84)
        self.url_entry.grid(row=1, column=1, sticky="w", pady=5, padx=5)
        
        # 备注
        tk.Label(input_frame, text="备注").grid(row=2, column=0, sticky="nw", pady=5)
        # self.notes_text = scrolledtext.ScrolledText(input_frame, width=30, height=4)
        self.notes_text = tk.Entry(input_frame, width=84)
        self.notes_text.grid(row=2, column=1, sticky="w", pady=5, padx=5)
        
        # 网站列表框架
        list_frame = tk.Frame(self.root)
        list_frame.pack(fill="both", expand=True, padx=20, pady=10)
        
        # 创建Treeview来显示网站列表,增加备注列
        columns = ("名称", "URL", "备注")  # 增加备注列
        self.website_list = ttk.Treeview(list_frame, columns=columns, show="headings", height=10)
        
        # 设置列标题
        self.website_list.heading("名称", text="网址名称")
        self.website_list.heading("URL", text="URL")
        self.website_list.heading("备注", text="备注")  # 增加备注列标题
        
        # 设置列宽,调整宽度总和超过列表框宽度以激活水平滚动
        self.website_list.column("名称", width=150, minwidth=150)
        self.website_list.column("URL", width=450, minwidth=450)
        self.website_list.column("备注", width=400, minwidth=400)  # 增加备注列
        
        # 添加滚动条
        v_scrollbar = ttk.Scrollbar(list_frame, orient="vertical", command=self.website_list.yview)
        h_scrollbar = ttk.Scrollbar(list_frame, orient="horizontal", command=self.website_list.xview)
        self.website_list.configure(yscrollcommand=v_scrollbar.set, xscrollcommand=h_scrollbar.set)
        
        # 布局Treeview和滚动条
        self.website_list.grid(row=0, column=0, sticky="nsew")
        v_scrollbar.grid(row=0, column=1, sticky="ns")
        h_scrollbar.grid(row=1, column=0, sticky="ew")
        
        # 配置网格权重
        list_frame.grid_rowconfigure(0, weight=1)
        list_frame.grid_columnconfigure(0, weight=1)
        
        # 绑定选择事件
        self.website_list.bind("<<TreeviewSelect>>", self.on_select)
        
        # 按钮框架
        button_frame = tk.Frame(self.root)
        button_frame.pack(fill="x", padx=20, pady=10)
        
        # 左侧按钮
        tk.Button(button_frame, text="打开选定网站", command=self.open_website).pack(side="left", padx=5)
        tk.Button(button_frame, text="清空", command=self.clear_fields).pack(side="left", padx=5)
        tk.Button(button_frame, text="帮助", command=self.show_help).pack(side="left", padx=5)
        
        # 右侧按钮
        tk.Button(button_frame, text="添加", command=self.add_website).pack(side="right", padx=5)
        tk.Button(button_frame, text="编辑", command=self.edit_website).pack(side="right", padx=5)
        tk.Button(button_frame, text="删除", command=self.delete_website).pack(side="right", padx=5)
        
        # 初始化网站列表
        self.refresh_list()
        
        # 初始状态设置为不可编辑
        self.toggle_editing()
        
    def toggle_editing(self):
        state = "normal" if self.edit_var.get() else "disabled"
        self.name_entry.config(state=state)
        self.url_entry.config(state=state)
        self.notes_text.config(state=state)
        
    def on_select(self, event):
        selected = self.website_list.selection()
        if selected:
            item = selected[0]
            values = self.website_list.item(item, "values")
            # 调整查询条件,包含备注字段
            website = next((w for w in self.websites if w["name"] == values[0] and w["url"] == values[1]), None)
            if website:
                self.name_entry.config(state="normal")
                self.url_entry.config(state="normal")
                self.notes_text.config(state="normal")
                
                self.name_entry.delete(0, tk.END)
                self.name_entry.insert(0, website["name"])
                
                self.url_entry.delete(0, tk.END)
                self.url_entry.insert(0, website["url"])
                
                #self.notes_text.delete(1.0, tk.END)
                #self.notes_text.insert(1.0, website.get("notes", ""))
                self.notes_text.delete(0, tk.END)
                self.notes_text.insert(0, website["notes"])
                
                self.toggle_editing()
                
    def clear_fields(self):
        self.name_entry.delete(0, tk.END)
        self.url_entry.delete(0, tk.END)
        #self.notes_text.delete(1.0, tk.END)
        self.notes_text.delete(0, tk.END)
        
    def open_website(self):
        selected = self.website_list.selection()
        if selected:
            item = selected[0]
            url = self.website_list.item(item, "values")[1]
            webbrowser.open(url)
        else:
            messagebox.showwarning("警告", "请先选择一个网站")
            
    def add_website(self):
        name = self.name_entry.get().strip()
        url = self.url_entry.get().strip()
        #notes = self.notes_text.get(1.0, tk.END).strip()
        notes = self.notes_text.get().strip()
        
        if not name or not url:
            messagebox.showwarning("警告", "网站名称和URL不能为空")
            return
            
        # 检查URL是否已存在
        if any(w["url"] == url for w in self.websites):
            messagebox.showwarning("警告", "该URL已存在")
            return
            
        self.websites.append({
            "name": name,
            "url": url,
            "notes": notes
        })
        
        self.refresh_list()
        self.clear_fields()
        self.save_data()
        messagebox.showinfo("成功", "网站已添加")
        
    def edit_website(self):
        selected = self.website_list.selection()
        if not selected:
            messagebox.showwarning("警告", "请先选择一个网站进行编辑")
            return
            
        name = self.name_entry.get().strip()
        url = self.url_entry.get().strip()
        notes = self.notes_text.get(1.0, tk.END).strip()
        
        if not name or not url:
            messagebox.showwarning("警告", "网站名称和URL不能为空")
            return
            
        item = selected[0]
        old_values = self.website_list.item(item, "values")
        old_url = old_values[1]
        
        # 检查URL是否已存在(排除自己)
        if any(w["url"] == url and w["url"] != old_url for w in self.websites):
            messagebox.showwarning("警告", "该URL已存在")
            return
            
        # 更新网站信息
        for website in self.websites:
            if website["url"] == old_url:
                website["name"] = name
                website["url"] = url
                website["notes"] = notes
                break
                
        self.refresh_list()
        self.save_data()
        messagebox.showinfo("成功", "网站信息已更新")
        
    def delete_website(self):
        selected = self.website_list.selection()
        if not selected:
            messagebox.showwarning("警告", "请先选择一个网站")
            return
            
        if messagebox.askyesno("确认", "确定要删除选定的网站吗?"):
            item = selected[0]
            url = self.website_list.item(item, "values")[1]
            
            # 从列表中删除
            self.websites = [w for w in self.websites if w["url"] != url]
            
            self.refresh_list()
            self.clear_fields()
            self.save_data()
            messagebox.showinfo("成功", "网站已删除")
            
    def refresh_list(self):
        # 清空列表
        for item in self.website_list.get_children():
            self.website_list.delete(item)
            
        # 添加网站到列表,包含备注信息
        for website in self.websites:
            self.website_list.insert("", "end", values=(
                website["name"], 
                website["url"], 
                website.get("notes", "")  # 增加备注显示
            ))
            
    def show_help(self):
        help_text = """
网站管理器使用说明:

1. 勾选"允许编辑"复选框后,可以编辑网站名称、URL和备注字段
2. 在右侧列表中选择一个网站,其信息将显示在左侧
3. 点击"打开选定网站"将在浏览器中打开选中的网站
4. 点击"清空"将清除所有输入字段
5. 点击"添加"将新网站添加到列表中(URL不能重复)
6. 点击"编辑"将修改选中的网站信息
7. 点击"删除"将从列表中移除选中的网站
注意:第一次运行时,由于websites.json不存在,会自动加载预设的默认网站数据。当新增、编辑、删除网站,会于当前目录下建立本地文件:websites.json。之后就会加载使用websites.json的数据。
        """
        messagebox.showinfo("帮助", help_text)
        
    def save_data(self):
        with open("websites.json", "w", encoding="utf-8") as f:
            json.dump(self.websites, f, ensure_ascii=False, indent=2)
            
    def load_data(self):
        # 如果文件存在,加载数据
        if os.path.exists("websites.json"):
            try:
                with open("websites.json", "r", encoding="utf-8") as f:
                    self.websites = json.load(f)
            except:
                # 若文件损坏或格式错误,初始化空列表
                self.websites = []
        else:
            # 否则使用默认数据
            self.websites = [
                {"name": "百度AI", "url": "https://chat.baidu.com", "notes": "百度智能对话平台"},
                {"name": "B站", "url": "https://www.bilibili.com", "notes": "视频分享平台,有很多学习资源"}
            ]

if __name__ == "__main__":
    root = tk.Tk()
    app = WebsiteManager(root)
    root.mainloop()

到此这篇关于基于Python实现网站网页管理小工具的文章就介绍到这了,更多相关Python网站网页管理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文