当前位置: 首页 > article >正文

【Python】——使用python实现GUI图书管理系统:Tkinter+SQLite实战

        本文将通过一个完整的python项目——图书管理系统,演示如何利用Tkinter构建GUI 界面,结合SQLite数据库实现增删改查功能。代码简洁易懂,适合python初学者学习和二次开发。

一、项目功能概览

  1. 图书管理:添加、查看、修改、删除图书信息
  2. 数据存储:使用SQLite持久化存储图书数据
  3. 可视化界面:表格展示数据,支持快速选择和编辑
  4. 输入校验:关键字段非空校验与操作确认提示

二、技术栈与依赖库


import tkinter as tk
from tkinter import ttk, messagebox
import sqlite3
  • Tkinter:Python标准GUI库,快速构建窗口应用
  • SQLite:轻量级嵌入式数据库,无需额外配置
  • Treeview:表格组件,支持数据多列展示

三、核心代码解析

1. 数据库设计
def create_table(self):
    cursor = self.conn.cursor()
    cursor.execute('''CREATE TABLE IF NOT EXISTS books
                      (id INTEGER PRIMARY KEY,
                       title TEXT NOT NULL,
                       author TEXT NOT NULL,
                       year INTEGER)''')
    self.conn.commit()
  • 创建books表,包含ID(主键)、书名、作者、出版年份字段
  • 使用IF NOT EXISTS避免重复建表
2. GUI界面布局

采用网格布局划分功能区域:

  • 输入区LabelFrame包含书名、作者、年份的输入框
  • 操作区:四个功能按钮(添加/显示/修改/删除)
  • 展示区Treeview表格+滚动条显示图书列表
3. 关键功能实现

添加图书(完整输入校验):

def add_book(self):
    title = self.title_entry.get()
    author = self.author_entry.get()
    year = self.year_entry.get()
    if title and author and year:
        cursor = self.conn.cursor()
        cursor.execute("INSERT INTO books VALUES (NULL,?,?,?)", 
                      (title, author, year))
        self.conn.commit()
        messagebox.showinfo("成功", "图书添加成功!")
        self.show_books()  # 刷新表格

数据绑定(点击表格自动填充输入框):

def on_tree_select(self, event):
    selected_items = self.tree.selection()
    if selected_items:
        item = selected_items[0]
        values = self.tree.item(item)['values']
        # 将选中数据回填至输入框
        self.title_entry.insert(0, values[1])
        self.author_entry.insert(0, values[2])
        self.year_entry.insert(0, values[3])

四、运行与使用

  1. 启动系统:执行python book_management.py
  2. 操作流程
    • 添加图书:填写信息 → 点击"添加图书"
    • 修改记录:选中表格行 → 编辑信息 → 点击"修改图书"
    • 删除记录:选中行 → 点击"删除图书" → 确认

 运行效果:


http://www.kler.cn/a/571783.html

相关文章:

  • 【Copilot极限实践日记】DAY 2: 使用Copilot/ChatGPT解决项目编译问题
  • 24、《Spring Boot 的 Actuator 监控深度解析》
  • 任务9:交换机基础及配置
  • Androidstudio使用BottomNavigationView 实现底部导航栏
  • C++类与对象:银行管理系统项目实战开发LeetCode每日一题
  • 系统架构设计师-第3章 数据库设计
  • 【jenkins配置记录】
  • 【在Spring Boot项目中接入Modbus协议】
  • PyTorch系列教程:评估和推理模式下模型预测
  • post get 给后端传参数
  • 爬虫系列之发送请求与响应《一》
  • 通俗版解释:分布式和微服务就像开餐厅
  • sa-token全局过滤器之写法优化(包含设置Order属性)
  • HiRT:利用分层机器人Transformer 增强机器人控制
  • 企业级Python后端数据库使用指南(简略版)
  • 计算机视觉算法实战——医学影像分割(主页有源码)
  • 深入解析Tiktokenizer:大语言模型中核心分词技术的原理与架构
  • Spring线程池学习笔记
  • [LeetCode]day33 150.逆波兰式求表达值 + 239.滑动窗口最大值
  • STM32MP1xx的启动流程