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

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

一、项目功能概览

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

二、技术栈与依赖库

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

三、核心代码解析

1. 数据库设计
python 复制代码
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. 关键功能实现

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

python 复制代码
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()  # 刷新表格

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

python 复制代码
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. 操作流程
    • 添加图书:填写信息 → 点击"添加图书"
    • 修改记录:选中表格行 → 编辑信息 → 点击"修改图书"
    • 删除记录:选中行 → 点击"删除图书" → 确认

运行效果:

相关推荐
+VX:Fegn08954 分钟前
计算机毕业设计|基于springboot + vue建筑材料管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
2301_800256116 分钟前
B+树:数据库的基石 R树:空间数据的索引专家 四叉树:空间划分的网格大师
数据结构·数据库·b树·机器学习·postgresql·r-tree
大厂技术总监下海28 分钟前
用户行为分析怎么做?ClickHouse + 嵌套数据结构,轻松处理复杂事件
大数据·数据结构·数据库
alonewolf_9938 分钟前
深入理解MySQL事务与锁机制:从原理到实践
android·数据库·mysql
朝依飞1 小时前
fastapi+SQLModel + SQLAlchemy2.x+mysql
数据库·mysql·fastapi
3***g2051 小时前
redis连接服务
数据库·redis·bootstrap
m0_598177231 小时前
SQL 方法函数(1)
数据库
oMcLin1 小时前
如何在Oracle Linux 8.4上通过配置Oracle RAC集群,确保企业级数据库的高可用性与负载均衡?
linux·数据库·oracle
信创天地1 小时前
核心系统去 “O” 攻坚:信创数据库迁移的双轨运行与数据一致性保障方案
java·大数据·数据库·金融·架构·政务
胖咕噜的稞达鸭1 小时前
进程间的通信(1)(理解管道特性,匿名命名管道,进程池,systeam V共享内存是什么及优势)重点理解代码!
linux·运维·服务器·数据库