首頁 > 軟體

Python實現GUI學生管理系統的範例程式碼

2022-06-24 14:02:38

序 言

哈嘍兄弟們,好久不見!最近實在太忙了,所以又雙叒叕斷更了~

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

寫完了放在那也是放著,所以今天分享給大家吧!

話不多說,咱們直接開始吧!

程式碼解析

一、登入頁面

1、定義登入類及初始化物件

首先匯入咱們需要用到的模組

from main import MainPage

登入頁面

將畫板繫結到範例物件

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()

以上就是Python實現GUI學生管理系統的範例程式碼的詳細內容,更多關於Python GUI學生管理系統的資料請關注it145.com其它相關文章!


IT145.com E-mail:sddin#qq.com