wxpython+sqlite3图书管理系统的全部代码

时间: 2024-01-13 16:03:28 浏览: 23
抱歉,由于代码篇幅较长,无法在此处完整展示。以下是一个简单的图书管理系统的 wxpython+sqlite3 代码示例,仅供参考: ```python import wx import sqlite3 class Book: def __init__(self, id, title, author, publisher, year): self.id = id self.title = title self.author = author self.publisher = publisher self.year = year class BookDatabase: def __init__(self): self.conn = sqlite3.connect('books.db') self.cur = self.conn.cursor() self.cur.execute("CREATE TABLE IF NOT EXISTS books (id INTEGER PRIMARY KEY, title TEXT, author TEXT, publisher TEXT, year INTEGER)") self.conn.commit() def add_book(self, book): self.cur.execute("INSERT INTO books VALUES (?, ?, ?, ?, ?)", (book.id, book.title, book.author, book.publisher, book.year)) self.conn.commit() def get_books(self): self.cur.execute("SELECT * FROM books") rows = self.cur.fetchall() books = [] for row in rows: books.append(Book(row[0], row[1], row[2], row[3], row[4])) return books def search_books(self, title): self.cur.execute("SELECT * FROM books WHERE title LIKE ?", ('%'+title+'%',)) rows = self.cur.fetchall() books = [] for row in rows: books.append(Book(row[0], row[1], row[2], row[3], row[4])) return books class BookPanel(wx.Panel): def __init__(self, parent): wx.Panel.__init__(self, parent) self.db = BookDatabase() self.book_list = wx.ListCtrl(self, style=wx.LC_REPORT) self.book_list.InsertColumn(0, 'ID') self.book_list.InsertColumn(1, 'Title') self.book_list.InsertColumn(2, 'Author') self.book_list.InsertColumn(3, 'Publisher') self.book_list.InsertColumn(4, 'Year') self.search_text = wx.TextCtrl(self) self.search_button = wx.Button(self, label='Search') self.search_button.Bind(wx.EVT_BUTTON, self.on_search) self.add_button = wx.Button(self, label='Add') self.add_button.Bind(wx.EVT_BUTTON, self.on_add) self.sizer = wx.BoxSizer(wx.VERTICAL) self.sizer.Add(self.book_list, 1, wx.EXPAND|wx.ALL, 5) self.sizer.Add(wx.StaticLine(self), 0, wx.EXPAND|wx.TOP|wx.BOTTOM, 5) search_box = wx.BoxSizer(wx.HORIZONTAL) search_box.Add(self.search_text, 1, wx.EXPAND|wx.RIGHT, 5) search_box.Add(self.search_button, 0, wx.RIGHT, 5) self.sizer.Add(search_box, 0, wx.EXPAND|wx.LEFT|wx.RIGHT|wx.BOTTOM, 5) button_box = wx.BoxSizer(wx.HORIZONTAL) button_box.Add(self.add_button, 0, wx.RIGHT, 5) self.sizer.Add(button_box, 0, wx.ALIGN_RIGHT|wx.RIGHT|wx.BOTTOM, 5) self.SetSizer(self.sizer) self.refresh_list() def refresh_list(self): self.book_list.DeleteAllItems() books = self.db.get_books() for book in books: index = self.book_list.InsertItem(self.book_list.GetItemCount(), str(book.id)) self.book_list.SetItem(index, 1, book.title) self.book_list.SetItem(index, 2, book.author) self.book_list.SetItem(index, 3, book.publisher) self.book_list.SetItem(index, 4, str(book.year)) def on_search(self, event): title = self.search_text.GetValue() books = self.db.search_books(title) self.book_list.DeleteAllItems() for book in books: index = self.book_list.InsertItem(self.book_list.GetItemCount(), str(book.id)) self.book_list.SetItem(index, 1, book.title) self.book_list.SetItem(index, 2, book.author) self.book_list.SetItem(index, 3, book.publisher) self.book_list.SetItem(index, 4, str(book.year)) def on_add(self, event): dlg = wx.TextEntryDialog(self, 'Enter book title:') if dlg.ShowModal() == wx.ID_OK: title = dlg.GetValue() dlg = wx.TextEntryDialog(self, 'Enter book author:') if dlg.ShowModal() == wx.ID_OK: author = dlg.GetValue() dlg = wx.TextEntryDialog(self, 'Enter book publisher:') if dlg.ShowModal() == wx.ID_OK: publisher = dlg.GetValue() dlg = wx.TextEntryDialog(self, 'Enter book year:') if dlg.ShowModal() == wx.ID_OK: year = dlg.GetValue() book = Book(None, title, author, publisher, year) self.db.add_book(book) self.refresh_list() class BookFrame(wx.Frame): def __init__(self): wx.Frame.__init__(self, None, title='Book Manager', size=(500, 400)) panel = BookPanel(self) self.Show() if __name__ == '__main__': app = wx.App() frame = BookFrame() app.MainLoop() ``` 该代码使用 wxpython 创建了一个简单的图书管理系统,用户可以添加、搜索和查看图书信息。该系统使用 sqlite3 数据库保存图书信息。请注意,该代码仅供参考,具体实现可能因需求不同而有所不同。

相关推荐

最新推荐

recommend-type

wxpython+pymysql实现用户登陆功能

wxpython最为一款python GUI库,由于简单和轻便外加强大的功能而受到很多python爱好者的喜爱,pymysql作为python3.x版本连接mysql库,应用也非常广泛。今天利用这两个库写一个简单的用户登陆的GUI窗口界面: 1.先看...
recommend-type

wxpython实现按钮切换界面的方法

主要为大家详细介绍了wxpython实现按钮切换界面的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

Python使用wxPython实现计算器

主要为大家详细介绍了Python使用wxPython实现计算器,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

wxPython实现窗口用图片做背景

主要为大家详细介绍了wxPython实现窗口用图片做背景,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

python wxpython 实现界面跳转功能

wxpython没提供界面跳转的方式,所以就需要借助threading模块,本文给大家分享python wxpython 实现界面跳转功能,感兴趣的朋友跟随小编一起看看吧
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

hive中 的Metastore

Hive中的Metastore是一个关键的组件,它用于存储和管理Hive中的元数据。这些元数据包括表名、列名、表的数据类型、分区信息、表的存储位置等信息。Hive的查询和分析都需要Metastore来管理和访问这些元数据。 Metastore可以使用不同的后端存储来存储元数据,例如MySQL、PostgreSQL、Oracle等关系型数据库,或者Hadoop分布式文件系统中的HDFS。Metastore还提供了API,使得开发人员可以通过编程方式访问元数据。 Metastore的另一个重要功能是跟踪表的版本和历史。当用户对表进行更改时,Metastore会记录这些更改,并且可以让用户回滚到
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。