表弟大學快畢業了,學了一個學期Python居然還不會寫學生管理系統,真的給我丟臉啊,教他又不肯學,還讓我直接給他寫,我真想兩巴掌上去,最侄訓是寫了給他,誰讓他是我表弟呢,關鍵時候還是得幫他一把!

寫完了放在那也是放著,所以今天分享給大家吧!
話不多說,咱們直接開始吧!

代碼決議
一、登錄頁面
1、定義登錄類及初始化物件
首先匯入咱們需要用到的模塊
from main import MainPage # 文章看不懂,我專門錄了對應的視頻講解,完整代碼和視頻教程加群獲取, # Python學習交流1裙:815624229 一群已滿加2群 ### # Python學習交流2裙:279199867 ###
登錄頁面
將畫板系結到實體物件
self.root = master
self.page 畫紙 在螢屏上顯示一個矩形區域,多用來作為容器,
self.page = tk.Frame(self.root) self.page.pack() self.root.geometry("300x180")
tkinter 提供的可變變數,定義用戶名和密碼.
self.username = tk.StringVar()
self.password = tk.StringVar()
創建一個label
網格布局
tk.Label(self.page).grid(row=0, column=0) # textvariable 這個引數是把 tkinter 里面的字串變數與 空間系結起來 tk.Label(self.page, text="賬戶").grid(row=1, column=0, stick=tk.E, pady=10) tk.Entry(self.page, textvariable=self.username).grid(row=1, column=1, stick=tk.W, pady=10) tk.Label(self.page, text="密碼").grid(row=2, column=0, stick=tk.E, pady=10) tk.Entry(self.page, textvariable=self.password).grid(row=2, column=1, stick=tk.W, pady=10)
command 接受一個函式 執行登錄的邏輯
tk.Button(self.page, text="登錄", command=self.login_check).grid(row=3, column=0, stick=tk.W, pady=10) tk.Button(self.page, text="退出", command=root.quit).grid(row=3, column=1, stick=tk.E, pady=10)
2、登錄函式
檢驗登錄
拿到賬號密碼
name = self.username.get()
pwd = self.password.get()
不去查詢資料庫
print(name, pwd) if name == 'admin' and pwd == '123456': tkinter.messagebox.showinfo(title='恭喜', message='登錄成功!')
摧毀當前頁面繪制的內容
self.page.destroy()
摧毀整個頁面繪制的內容
self.root.destroy()
頁面的切換
MainPage(self.root) else: tkinter.messagebox.showinfo(title='錯誤', message='賬戶或者密碼錯誤')
3、視窗呼叫
呼叫本檔案方法,在本檔案運行兩個輸入,在外面呼叫執行這個方法前面的資料,
創建一個物件,視窗物件,顯示界面.
if __name__ == '__main__': root = tk.Tk() LoginPage(root) root.mainloop()
二、主頁面顯示
1、定義頁面類,方便呼叫.
登錄界面
def __init__(self, master): self.root = master self.page = tk.Frame(self.root) self.page.pack() self.root.geometry("%dx%d" % (600, 400)) self.create_page()
創建一個頂級選單,顯示選單.
def create_page(self): menubar = tk.Menu(self.root) menubar.add_command(label="錄入") menubar.add_command(label="查詢") menubar.add_command(label="洗掉") menubar.add_command(label="修改") menubar.add_command(label="關于")
三 、頁面顯示
1、系結各個頁面
寫在一起代碼太多,資料多,容易寫錯,混亂,可以寫一個檔案專門來裝資料view.py
在view.py檔案定義各個模塊的類
錄入
class InputFrame(tk.Frame): # 繼承Frame類 def __init__(self, master): # 重新父類 super().__init__(master) pass
查詢
class QueryFrame(tk.Frame): # 繼承Frame類 def __init__(self, master=None): super().__init__(master) pass
洗掉
class DeleteFrame(tk.Frame): # 繼承Frame類 def __init__(self, master=None): super().__init__(master)
修改
class ChangeFrame(tk.Frame): # 繼承Frame類 def __init__(self, master=None): super().__init__(master)
關于
class AboutFrame(tk.Frame): # 繼承Frame類 def __init__(self, master=None): tk.Frame.__init__(self, master) self.root = master
然后在main.py檔案中系結這些資料
self.input_page = InputFrame(self.root) self.change_page = ChangeFrame(self.root) self.query_page = QueryFrame(self.root) self.delete_page = DeleteFrame(self.root) self.about_page = AboutFrame(self.root)
2、錄入
在view.py檔案中InputFrame類中添加相關內容,名字以及成績,
- x = IntVar():整型變數,默認是0
- x = DoubleVar():浮點型變數,默認是0.0
- x = StringVar():字串變數,默認是""
- x = BooleanVar():布爾型變數,True是1,False是0
self.root = master # 定義內部變數root self.name = tk.StringVar() self.math = tk.StringVar() self.chinese = tk.StringVar() self.english = tk.StringVar() # 錄入 self.status = tk.StringVar() # 呼叫create_page()函式 self.create_page()
撰寫create_page()函式
def create_page(self): # pass # stick 控制元件物件方向 tk.W 西方位 # pady padding y 上下的寬度 # row 行 表格布局 tk.Label(self).grid(row=0, stick=tk.W, pady=10) tk.Label(self, text='姓 名: ').grid(row=1, stick=tk.W, pady=10) # text variable 系結控制元件里面的資料內容 tk.Entry(self, textvariable=self.name).grid(row=1, column=1, stick=tk.E) tk.Label(self, text='數 學: ').grid(row=2, stick=tk.W, pady=10) tk.Entry(self, textvariable=self.math).grid(row=2, column=1, stick=tk.E) tk.Label(self, text='語 文: ').grid(row=3, stick=tk.W, pady=10) tk.Entry(self, textvariable=self.chinese).grid(row=3, column=1, stick=tk.E) tk.Label(self, text='英 語: ').grid(row=4, stick=tk.W, pady=10) tk.Entry(self, textvariable=self.english).grid(row=4, column=1, stick=tk.E) tk.Button(self, text='錄入', command=self.recode_student).grid(row=5, column=1, stick=tk.E, pady=10) tk.Label(self, textvariable=self.status).grid(row=6, column=1, stick=tk.E, pady=10)
在main.py中系結這些資料
menubar.add_command(label="錄入", command=self.show_input) def show_input(self): self.input_page.pack() # pack_forget()隱藏布局 # self.change_page.pack_forget() # self.query_page.pack_forget() # self.delete_page.pack_forget() # self.about_page.pack_forget()
在view.py檔案中資料錄入
def recode_student(self): stu = {'name': self.name.get(), 'chinese': self.chinese.get(), 'math': self.math.get(), 'english': self.english.get()} # 點擊錄入之后需要重繪頁面 self.name.set('') self.chinese.set('') self.math.set('') self.english.set('') db.insert(stu) self.status.set('提交資料成功') print(stu)
插入資料及保存資料,可以寫一個檔案保存,寫在一起代碼量太大,出現錯誤機率也大寫一個db.py檔案.
class StudentsDB: def __init__(self): self.students = [] def insert(self, student): self.students.append(student) db = StudentsDB() if __name__ == '__main__': print(db.students)
四、查詢資料
在QueryFrame()類添加資料
-
ttk.Treeview 樹視圖,百度一下
-
shows:
headings
tree
data_list -
columns
值是一個串列,串列里每個元素代表一個列識別符號的名稱,串列的長度為列的長度,
繼承Frame類
class QueryFrame(tk.Frame): def __init__(self, master=None): super().__init__(master)
定義內部變數root
self.root = master # columns = ('name', 'chinese', 'math', 'english') self.tree_view = ttk.Treeview(self, show='headings', columns=columns)
每個資料大小每一格
self.tree_view.column('name', width=80, anchor='center') self.tree_view.column('chinese', width=80, anchor='center') self.tree_view.column('math', width=80, anchor='center') self.tree_view.column('english', width=80, anchor='center')
上面的標簽及headings
self.tree_view.heading('name', text='姓名') self.tree_view.heading('chinese', text='語文') self.tree_view.heading('math', text='數學') self.tree_view.heading('english', text='英語') self.tree_view.pack(fill=tk.BOTH, expand=True) tk.Button(self, text='重繪資料', command=self.show_data_frame).pack(anchor=tk.E, pady=5) self.show_data_frame()
重繪資料,顯示資料.
def show_data_frame(self): # 洗掉舊的階段 for _ in map(self.tree_view.delete, self.tree_view.get_children('')): pass # 先要顯示所有資料 在db檔案加入顯示資料代碼 students = db.all() index = 0 for stu in students: # print(stu) self.tree_view.insert('', index + 1, values=( stu['name'], stu['chinese'], stu['math'], stu['english'], ))
顯示資料
在db.py中加
def all(self): return self.students
view.py
重繪插入資料
- 第一個引數:parent : 對于有樹欄的Treeview,parent是父節點,對于只是串列欄的Treeview,parent一般為空,
- 第二個引數:index :插入位置,可以是END或’end’ ,也可以是數字的,如果你想新插入的item(記錄)成為第某節點的第一個,index就設為0,以此類推,
- values:顯示的值及插入的資料,這一列資料,
self.tree_view.insert('', index + 1, values=( stu['name'], stu['chinese'], stu['math'], stu['english'], ))
插入資料重繪后更新頁面
- map(func, lst),將傳入的函式變數func作用到lst變數的每個元素中,并將結果組成新的串列(Python2)/迭代器(Python3)回傳,
- get_children(item=None)
回傳一個item的所有子item,這個子item是一個串列形式,如果item沒指定,則回傳根目錄的item
for _ in map(self.tree_view.delete, self.tree_view.get_children('')): pass
在main.py檔案系結資料
menubar.add_command(label="查詢", command=self.show_all) def show_all(self): # 隱藏布局 self.input_page.pack_forget() # self.change_page.pack_forget() self.query_page.pack() # self.delete_page.pack_forget() # self.about_page.pack_forget()
五、洗掉資料
在DeleteFrame()類添加資料
class DeleteFrame(tk.Frame): # 繼承Frame類 def __init__(self, master=None): super().__init__(master) self.root = master # 定義內部變數root tk.Label(self, text='洗掉資料').pack() self.delete_frame = tk.Frame(self) self.delete_frame.pack() self.status = tk.StringVar() self.username = tk.StringVar() tk.Label(self.delete_frame, text='根據名字洗掉資訊').pack(anchor=tk.W, padx=20) tk.Entry(self.delete_frame, textvariable=self.username).pack(side=tk.LEFT, padx=20, pady=5) tk.Button(self.delete_frame, text='洗掉', command=self._delete).pack() tk.Label(self, textvariable=self.status).pack()
1、點擊洗掉,洗掉資料
def _delete(self): username = self.username.get() flag, message = db.delete_by_name(username) self.status.set(message)
在db.py檔案中添加洗掉邏輯
def delete_by_name(self, name): for student in self.students: if name == student['name']: self.students.remove(student) return True, f'{name} 洗掉成功' return False, f'{name} 不存在'
在main.py中系結資料
menubar.add_command(label="洗掉", command=self.show_delete) def show_delete(self): self.input_page.pack_forget() self.query_page.pack_forget() self.delete_page.pack()
六、修改資料
在ChangeFrame()類添加資料
self.root = master # 定義內部變數root tk.Label(self, text='修改界面').pack() self.change_frame = tk.Frame(self) self.change_frame.pack() self.status = tk.StringVar() self.name = tk.StringVar() self.math = tk.StringVar() self.chinese = tk.StringVar() self.english = tk.StringVar() tk.Label(self.change_frame).grid(row=0, stick=tk.W, pady=1) tk.Label(self.change_frame, text='姓 名: ').grid(row=1, stick=tk.W, pady=10) tk.Entry(self.change_frame, textvariable=self.name).grid(row=1, column=1, stick=tk.E) tk.Label(self.change_frame, text='數 學: ').grid(row=2, stick=tk.W, pady=10) tk.Entry(self.change_frame, textvariable=self.math).grid(row=2, column=1, stick=tk.E) tk.Label(self.change_frame, text='語 文: ').grid(row=3, stick=tk.W, pady=10) tk.Entry(self.change_frame, textvariable=self.chinese).grid(row=3, column=1, stick=tk.E) tk.Label(self.change_frame, text='英 語: ').grid(row=4, stick=tk.W, pady=10) tk.Entry(self.change_frame, textvariable=self.english).grid(row=4, column=1, stick=tk.E) tk.Button(self.change_frame, text='查詢', command=self._search).grid(row=6, column=0, stick=tk.W, pady=10) tk.Button(self.change_frame, text='修改', command=self._change).grid(row=6, column=1, stick=tk.E, pady=10) tk.Label(self.change_frame, textvariable=self.status).grid(row=7, column=1, stick=tk.E, pady=10)
1、查詢資料
db.py檔案中查詢資料邏輯
def search_by_name(self, name): for student in self.students: if name == student['name']: return True, student return False, f'{name} 不存在'
view.py檔案點擊查詢,顯示資料
def _search(self): flag, info = db.search_by_name(self.name.get()) if flag: self.name.set(info['name']) self.chinese.set(info['chinese']) self.math.set(info['math']) self.english.set(info['english']) self.status.set('資料查詢成功') else: # 直接回傳錯誤的資訊 self.status.set(info)
2、修改資料及更新
db.py檔案更新資料邏輯
def update(self, stu): name = stu['name'] for student in self.students: if name == student['name']: student.update(stu) return True, f'{stu["name"]} 用戶資料修改成功' else: return False, f'{name} 不存在'
view.py檔案修改資料
def _change(self): stu = {'name': self.name.get(), 'chinese': self.chinese.get(), 'math': self.math.get(), 'english': self.english.get(), } self.name.set('') self.chinese.set('') self.math.set('') self.english.set('') db.update(stu) self.status.set('修改資料成功')
main.py檔案進行系結
menubar.add_command(label="修改", command=self.show_change) def show_change(self): self.input_page.pack_forget() self.query_page.pack_forget() self.delete_page.pack_forget() self.change_page.pack()
七、關于部分
view.py中在AboutFrame()添加資料
class AboutFrame(tk.Frame): # 繼承Frame類 def __init__(self, master=None): tk.Frame.__init__(self, master) self.root = master # 定義內部變數root tk.Label(self, text='關于作品:本作品由 嗨學編程 制作').pack(anchor=tk.W) tk.Label(self, text='關于作者:嗨學編程').pack(anchor=tk.W) tk.Label(self, text='著作權所有:嗨學編程').pack(anchor=tk.W)
main.py系結資料
menubar.add_command(label="關于", command=self.show_about) def show_about(self): self.input_page.pack_forget() self.query_page.pack_forget() self.delete_page.pack_forget() self.change_page.pack_forget() self.about_page.pack()
八、資料保存,保存資訊
db.py對資料保存
創建空json檔案
import os file = "students.json" # 判斷檔案是否存在,不存在則創建 if not os.path.exists(file): open(file, 'w') # 報錯 # os.mknod(file)
- Windows上的Python不支持mknod函式,因為在Windows上沒有node這個概念,
1、保存資料
def save_data(self): with open('students.json', mode='w', encoding='utf-8') as f: text = json.dumps(self.students, indent=2, ensure_ascii=False) f.write(text)
2 、讀取資料
def _load_students_data(self): with open('students.json', mode='r', encoding='utf-8') as f: text = f.read() if text: self.students = json.loads(text)
在view.py檔案中呼叫保存函式,對完成后的資料進行保存,
錄入
def recode_student(self): db.save_data()
洗掉
def _delete(self): db.save_data()
修改
def _change(self): db.save_data()
好了今天的分享就到這里,兄弟們下次見!
大家覺得有幫助的話,順手點個關注+贊+收藏吧,愛你們!
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/495518.html
標籤:Python
上一篇:5個節約生命的Python小技巧
