Python開發程式:學員管理系統(mysql)

来源:http://www.cnblogs.com/lianzhilei/archive/2016/10/30/6013847.html
-Advertisement-
Play Games

主題:學員管理系統 需求: 用戶角色,講師\學員, 用戶登陸後根據角色不同,能做的事情不同,分別如下 講師視圖: 管理班級,可創建班級,根據學員qq號把學員加入班級 可創建指定班級的上課紀錄,註意一節上課紀錄對應多條學員的上課紀錄, 即每節課都有整班學員上, 為了紀錄每位學員的學習成績,需在創建每節 ...


主題:學員管理系統

需求:

用戶角色,講師\學員, 用戶登陸後根據角色不同,能做的事情不同,分別如下

講師視圖:

  •   管理班級,可創建班級,根據學員qq號把學員加入班級
  •   可創建指定班級的上課紀錄,註意一節上課紀錄對應多條學員的上課紀錄, 即每節課都有整班學員上, 為了紀錄每位學員的學習成績,需在創建每節上課紀錄是,同時為這個班的每位學員創建一條上課紀錄
  •   為學員批改成績, 一條一條的手動修改成績

學員視圖:

  • 提交作業
  • 查看作業成績
  • 一個學員可以同時屬於多個班級,就像報了Linux的同時也可以報名Python一樣, 所以提交作業時需先選擇班級,再選擇具體上課的節數
  • 附加:學員可以查看自己的班級成績排名

 

表結構:

根據需求先畫表結構

 

程式目錄結構:

 

表結構實例代碼:

from sqlalchemy import String,Column,Integer,ForeignKey,DATE,Table
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import relationship
from conf.settings import engine


############創建數據表結構######################3
Base = declarative_base()

# 班級與學生的對應關係表
teacher_m2m_class = Table("teacher_m2m_class",Base.metadata,
                          Column("teacher_id", Integer, ForeignKey("teacher.teacher_id")),
                          Column("class_id", Integer, ForeignKey("class.class_id")),
                          )

# 班級與學生的對應關係表
class_m2m_student = Table("class_m2m_student",Base.metadata,
                          Column("class_id",Integer,ForeignKey("class.class_id")),
                          Column("stu_id", Integer, ForeignKey("student.stu_id")),
                          )

class Class_m2m_Lesson(Base):
    '''班級和課節對應表'''
    __tablename__ = "class_m2m_lesson"
    id =  Column(Integer, primary_key=True)
    class_id = Column(Integer,ForeignKey("class.class_id"))
    lesson_id = Column(Integer, ForeignKey("lesson.lesson_id"))

    classes = relationship("Class",backref="class_m2m_lessons")
    lessons = relationship("Lesson", backref="class_m2m_lessons")

    def __repr__(self):
        return "%s %s" % (self.classes,self.lessons)

class Study_record(Base):
    "上課記錄"
    __tablename__ = "study_record"
    id = Column(Integer,primary_key=True)
    class_m2m_lesson_id = Column(Integer,ForeignKey("class_m2m_lesson.id"))
    stu_id = Column(Integer, ForeignKey("student.stu_id"))
    status = Column(String(32),nullable=False)
    score = Column(Integer,nullable=True)

    class_m2m_lessons = relationship("Class_m2m_Lesson",backref="my_study_record")
    students = relationship("Student", backref="my_study_record")

    def __repr__(self):
       return  "\033[35;0m%s,%s,狀態:【%s】,成績:【%s】\33[0m"%(self.class_m2m_lessons,self.students,self.status,self.score)

class Teacher(Base):
    "講師"
    __tablename__ = "teacher"
    teacher_id = Column(Integer, primary_key=True)
    teacher_name = Column(String(32), nullable=False, unique=True)   #唯一

    classes = relationship("Class", secondary=teacher_m2m_class, backref="teachers")

    def __repr__(self):
        return "講師:【%s】"%self.teacher_name

class Class(Base):
    "班級"
    __tablename__ ="class"
    class_id = Column(Integer, primary_key=True)
    class_name = Column(String(32), nullable=False,unique=True)
    course =  Column(String(32), nullable=False)

    students = relationship("Student",secondary=class_m2m_student,backref="classes")

    def __repr__(self):
        return "班級名:【%s】"%self.class_name

class Student(Base):
    "學生"
    __tablename__ ="student"
    stu_id = Column(Integer, primary_key=True)
    stu_name = Column(String(32), nullable=False, unique=True)
    QQ =  Column(Integer(), nullable=False)

    def __repr__(self):
        return "學生名:【%s】"%self.stu_name

class Lesson(Base):
    "課節"
    __tablename__ = "lesson"
    lesson_id = Column(Integer, primary_key=True)
    lesson_name = Column(String(32), nullable=False, unique=True)

    def __repr__(self):
        return "節次名:【%s】"%self.lesson_name


Base.metadata.create_all(engine)

 

創建學習記錄以及修改學生成績:

def add_studyrecord(self):
        '''添加學習記錄'''
        class_name = input("\033[34;0m請輸入要添加學習記錄的班級名:\033[0m")
        class_obj = self.session.query(Class).filter_by(class_name=class_name).first()

        if class_obj and class_obj.teachers[0] == self.teacher_obj:  # 輸入的班級名存在且在屬於當前老師管理
            lesson_name = input("\033[34;0m請輸入添加學習記錄的課節名(lesson):\033[0m")
            lesson_obj = self.session.query(Lesson).filter_by(lesson_name=lesson_name).first()
            if lesson_obj:                                       # 輸入的lesson名字存在
                class_m2m_lesson_obj = self.session.query(Class_m2m_Lesson).filter(Class_m2m_Lesson.class_id == class_obj.class_id). \
                    filter(Class_m2m_Lesson.lesson_id == lesson_obj.lesson_id).first()
                if class_m2m_lesson_obj:                                            # 班級對應的課lesson表數據存在

                    study_record_obj = self.session.query(Study_record).filter_by(class_m2m_lesson_id=class_m2m_lesson_obj.id).first()
                    if not study_record_obj:                                                    # 上課記錄為創建
                        for student_obj in class_obj.students:
                            status = input("輸入學生 %s 的上課狀態(yes/no):"%student_obj.stu_name)
                            study_record_new = Study_record(class_m2m_lesson_id=class_m2m_lesson_obj.id,
                                                            stu_id=student_obj.stu_id,
                                                            status=status)
                            self.session.add(study_record_new)
                            self.session.commit()
                    else:
                        print("\33[31;1m系統錯誤:當前上課記錄已經創建\33[0m")
                else:
                     print("\33[31;1m系統錯誤:當前班級的lesson課節未創建\33[0m")
            else:
                print("\33[31;1m系統錯誤:lesson未創建\33[0m")
        else:
            print("\33[31;1m輸入錯誤:班級不存在或沒有許可權管理此班級\33[0m")


    def modify_scores(self):
        '''修改成績'''
        class_name = input("\033[34;0m請輸入學習記錄的班級名:\033[0m")
        class_obj = self.session.query(Class).filter_by(class_name=class_name).first()

        if class_obj and class_obj.teachers[0] == self.teacher_obj:  # 輸入的班級名存在且在屬於當前老師管理
            lesson_name = input("\033[34;0m請輸入學習記錄的課節名(lesson):\033[0m")
            lesson_obj = self.session.query(Lesson).filter_by(lesson_name=lesson_name).first()

            if lesson_obj:  # 輸入的lesson名字存在
                class_m2m_lesson_obj = self.session.query(Class_m2m_Lesson).filter(
                    Class_m2m_Lesson.class_id == class_obj.class_id). \
                    filter(Class_m2m_Lesson.lesson_id == lesson_obj.lesson_id).first()

                if class_m2m_lesson_obj:  # 班級對應的課lesson表數據存在
                    while True:
                        study_record_objs = self.session.query(Study_record).filter(
                                Study_record.class_m2m_lesson_id==class_m2m_lesson_obj.id).all()
                        for obj in  study_record_objs:
                            print(obj)

                        student_name = input("\033[34;0m輸入要修改成績的學生名:[Q 退出]\33[0m")
                        if student_name == "q" or student_name == "Q":break
                        student_obj = self.session.query(Student).filter_by(stu_name=student_name).first()
                        if student_obj:
                            study_record_obj = self.session.query(Study_record).filter(
                                Study_record.class_m2m_lesson_id==class_m2m_lesson_obj.id).filter(
                                Study_record.stu_id == student_obj.stu_id).first()

                            if study_record_obj:                            # 上課記錄存在
                                score = input("\033[34;0m輸入修改後的成績\33[0m")
                                study_record_obj.score= score
                                self.session.commit()

                    else:
                        print("\33[31;1m系統錯誤:當前上課記錄已經創建\33[0m")
                else:
                    print("\33[31;1m系統錯誤:當前班級的lesson課節未創建\33[0m")
            else:
                print("\33[31;1m系統錯誤:lesson未創建\33[0m")
        else:
            print("\33[31;1m輸入錯誤:班級不存在或沒有許可權管理此班級\33[0m")

 

上面的兩段代碼實現了主要的功能,其他的功能都是套路,都一樣。。。。

 

完整代碼地址--》》https://coding.net/u/James_Lian/p/Whaterver/git/tree/master

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 測試與基本規範 為什麼需要測試? 為了穩定性,能夠明確的瞭解是否正確的完成開發。 更加易於維護,能夠在修改代碼後保證功能不被破壞。 集成一些工具,規範開發規範,使得代碼更加穩定( 如通過 phabricator differential 發diff時提交需要執行的單元測試,在開發流程上就可以保證遠端 ...
  • 英文文檔: help([object]) Invoke the built-in help system. (This function is intended for interactive use.) If no argument is given, the interactive help s ...
  • 需求: 1、springmvc返回xml; 技術及環境: 實現: spirngxml的配置主要如下: 添加項目依賴: 實體類JavaBean 一個簡單的JavaBean,添加了JAXB 註解,spring將會根據請求判斷轉換成xml。JAXB不需要添加額外的依賴庫,已經包含在jdk中。 spring ...
  • (1) 編寫一個程式,生成一個10*10的二維隨機整數數組,並將該數組的每行最大值保存於一個一維數組中,將每列平均值保存於另外一個一維數組中並分別輸出。 (2) 編程輸出楊輝三角的前10行。 找出一個,即該位置上的元素在該行上最大,在該列上最小(註:一個二維數組也可能沒有這樣的鞍點)。 /** * ...
  • 話說好久沒更新這個博客了 都快忘記還有博客這件事了.... 因為之前在造一個簡單的HTTP框架的輪子,裡面用了JSON...當時隨便拉了個FastJSON的庫就用了,然而...嗯,毫無疑問,輪子還是要自己造才好玩,雖然不會在生產環境用,但是寫和不寫多少還是有些差距的 於是今天就造了這個簡單的JSON ...
  • 用c語言寫了kmeans演算法的串列程式,再用mpi來寫並行版的,貌似參照著串列版來寫並行版,效果不是很賞心悅目~ 並行化思路: 使用主從模式。由一個節點充當主節點負責數據的劃分與分配,其他節點完成本地數據的計算,並將結果返回給主節點。大致過程如下: 1、進程0為主節點,先從文件中讀取數據集,然後將數 ...
  • 最近發現以前寫的項目全亂碼了。唯獨 .java 中的中文全是亂碼。 由於,後期的項目把預設編碼改成了UTF-8所以就亂了。 每個編碼表的編碼都不一樣。不能直接通過改某個屬性來更改達到目的 (除非你是第一次調環境來定義該項目以什麼編碼形式來編譯。) String s="中國"; byte [] by= ...
  • Qt 中的QT_BEGIN_NAMESPACE 巨集的作用. 當前博文,等待以後的我,明白以後, 再來補充... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...