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

运行效果:

相关推荐
阿正的梦工坊4 分钟前
【Rust】05-结构体、枚举与模式匹配
java·数据库·rust
cjp5606 分钟前
006.WEB_API使用本地数据库 SQLite + Dapper 入门教程
数据库·sqlite
新新学长搞科研8 分钟前
【广东省博促会主办】2026年第七届先进材料与智能制造国际学术会议(ICAMIM 2026)
大数据·前端·数据库·人工智能·物联网
睡不醒男孩03082310 分钟前
CLup篇之PostgreSQL管理
数据库·postgresql
瀚高PG实验室11 分钟前
数据库启动报错:42501: 无法打开共享内存段 “/PostgreSQL.******“: 权限不够
数据库·postgresql·瀚高数据库
持敬chijing24 分钟前
Web渗透之SQL注入-SQLMAP使用笔记
数据库·sql·安全·web安全·网络安全·网络攻击模型
瀚高PG实验室24 分钟前
流复制备库停机维护前检查步骤
数据库·瀚高数据库·highgo
BomanGe235 分钟前
NSK直线导轨LH55EL与NH55EM替代指南
前端·javascript·数据库·经验分享·规格说明书
JAVA面经实录91736 分钟前
MongoDB(文档型 NoSQL)
java·数据库·mongodb·nosql
睡不醒男孩03082338 分钟前
第十篇:PostgreSQL 生产环境高可用选型:CLUP 与 Patroni 深度架构对比与踩坑实录
数据库·postgresql·架构