db.py
import json
class StudentDB(object):
def init(self):
self.students = []
self._load_students_data()
def insert(self, student):
self.students.append(student)
print(self.students)
def all(self):
return self.students
def delete_by_name(self, name): # 删除数据
for student in self.students:
if name == student[“name”]:
self.students.remove(student)
break
else:
return False
return True
查询
def search_by_name(self, name):
for student in self.students:
if name == student[“name”]:
return student # 姓名+成绩
else:
return False
修改
def update(self, stu): # 修改数据
name = stu[“name”]
for student in self.students:
if name == student[“name”]:
student.update(stu)
return True
else:
return False
加载文件
def _load_students_data(self):
with open(“students.txt”, “r”, encoding=“utf-8”) as f:
text = f.read()
if text:
self.students = json.loads(text)
保存数据
def save_data(self):
with open(“students.txt”, ‘w’, encoding=“utf-8”) as f:
text = json.dumps(self.students, ensure_ascii=False)
f.write(text)
db = StudentDB()
MenuPage.py
import tkinter as tk
from view import *
class MenuPage(object):
def init(self, master=None):
self.root = master
self.root.geometry(‘%dx%d’ % (600, 400))
self.create_page()
self.input_page = InputFrame(self.root)
self.query_page = QuerryFrame(self.root)
self.delete_page = DeleteFrame(self.root)
self.update_page = UpdateFrame(self.root)
self.about_page = AboutFrame(self.root)
self.input_page.pack()
def create_page(self):
创建菜单对象
menubar = tk.Menu(self.root)
add_command 添加
menubar.add_command(label=“录入”, command=self.input_data) # label
menubar.add_command(label=“查询”, command=self.query_data) # label
menubar.add_command(label=“删除”, command=self.delete_data) # label
menubar.add_command(label=“修改”, command=self.update_data) # label
menubar.add_command(label=“关于”, command=self.about_data) # label
设置菜单栏
self.root.config(menu=menubar)
切换界面
def input_data(self):
self.input_page.pack()
self.update_page.pack_forget()
self.delete_page.pack_forget()
self.about