Python小项目——学生信息管理系统(详细讲解)
目錄
一、需求分析
????????1、學生管理系統應具備的功能
二、系統設計
1、系統功能結構
2、系統業務流程
三、系統開發必備工具?
? ? ? ? 1、系統開發環境
? ? ? ? 2、項目目錄結構
?四、主函數設計
? ? ? ? ?1、系統主界面運行效果圖
? ? ? ? 2、主函數的業務流程
?????????3、實現主函數
? ? ? ? 4、代碼與結果演示及講解
? 五、學生信息維護模式設計
? ? ? ? 1、錄入學生信息功能
? ? ? ? ? ? ? ? 1、1實現錄入學生信息功能
? ? ? ? ? ? ? ? 1、2業務流程
? ? ? ? ? ? ? ? 1、3具體實現?
? ? ? ? ? ? ? ? 1、4代碼與結果演示及講解
? ? ? ? 2、刪除學生信息功能
? ? ? ? ? ? ? ? 2、1實現刪除學生信息功能
? ? ? ? ? ? ? ? 2、2業務流程
? ? ? ? ? ? ? ? 2、3具體實現?
? ? ? ? ? ? ? ? 2、4代碼與結果演示及講解
? ? ? ? 3、修改學生信息功能
? ? ? ? ? ? ? ? 3、1實現學生信息修改功能
? ? ? ? ? ? ? ? 3、2業務流程
? ? ? ? ? ? ? ? 3、3具體實現
? ? ? ? ? ? ? ? ?3、4代碼與結果演示及講解
六、查詢/統計模塊設計
? ? ? ? 1、查找學生信息功能
? ? ? ? ? ? ? ? 1、1實現查詢學生信息功能
? ? ? ? ? ? ? ??1、2業務流程
?? ? ? ? ? ? ? ? ? ? ? ? 1、3具體實現?
? ? ? ? ? ? ? ? ? ? ? ? ?1、4代碼與結果演示及講解
? ? ? ? 2、統計學生總人數
? ? ? ? ? ? ? ? 2、1實現統計學生總人數功能
? ? ? ? ? ? ? ? 2、2業務流程
? ? ? ? ? ? ? ? 2、3具體實現
? ? ? ? ? ? ? ? 2、4?代碼與結果演示及講解
? ? ? ? 3、顯示所有學生信息功能
? ? ? ? ? ? ? ? 3、1實現顯示所有學生信息功能
? ? ? ? ? ? ? ? 3、2業務流程
? ? ? ? ? ? ? ? 3、3具體實現
? ? ? ? ? ? ? ? 3、4代碼與結果演示及講解
七、排序模塊設計
? ? ? ? 1、排序模塊的設計
? ? ? ? ? ? ? ? 1、1實現按學生成績排序功能
? ? ? ? ? ? ? ? 1、2業務流程
? ? ? ? ? ? ? ? 1、3具體實現
? ? ? ? ? ? ? ? ? ?1、4代碼與結果演示及講解
?八、總結
一、需求分析
????????1、學生管理系統應具備的功能
????????????????①添加學生及成績信息
????????????????②將學生信息保存到文件中
????????????????③修改和刪除學生信息
????????????????④查詢學生信息
????????????????⑤根據學生成績進行排序
????????????????⑥統計學生的總分
二、系統設計
1、系統功能結構
? ? ? ? 1.1學生信息管理系統的7大模塊
? ? ? ? ? ? ? ? ①錄入學生信息模塊(insert())
? ? ? ? ? ? ? ? ②查找學生信息模塊(search())
? ? ? ? ? ? ? ? ③刪除學生信息模塊(delete())
? ? ? ? ? ? ? ? ④修改學生信息模塊(modify())
? ? ? ? ? ? ? ? ⑤學生成績排名模塊(sort())
? ? ? ? ? ? ? ? ⑥統計學生總人數模塊(total())
? ? ? ? ? ? ? ? ⑦顯示全部學生信息模塊
2、系統業務流程
三、系統開發必備工具?
? ? ? ? 1、系統開發環境
? ? ? ? ? ? ? ? 操作系統:win7
? ? ? ? ? ? ? ? Python解釋器版本:Python3.8
? ? ? ? ? ? ? ? 開發工具:PyCharm
? ? ? ? ? ? ? ? Python內置模塊:os,re
? ? ? ? 2、項目目錄結構
????????????????
?四、主函數設計
? ? ? ? ?1、系統主界面運行效果圖
? ? ? ? 2、主函數的業務流程
?????????3、實現主函數
? ? ? ? 4、代碼與結果演示及講解
? ? ? ? ? ? ? ? ①實現主函數之前要先把主菜單函數設計好,及我們的menum();菜單設計相對簡單,只需要根據我們的設計,照樣輸出即可。
def menum():#菜單print("===========================學生信息管理系統==========================")print('-------------------------------功能菜單----------------------------')print('\t\t\t\t\t\t1.錄入學生信息')print('\t\t\t\t\t\t2.查找學生信息')print('\t\t\t\t\t\t3.刪除學生信息')print('\t\t\t\t\t\t4.修改學生信息')print('\t\t\t\t\t\t5.對學生成績排序')print('\t\t\t\t\t\t6.統計學生總人數')print('\t\t\t\t\t\t7.顯示所有學生總數')print('\t\t\t\t\t\t0.退出系統')print('-----------------------------------------------------------------------')?????????????????②在主函數中顯示主菜單,然后進行循環,因為信息可以一直加,所以循環采用的是while True:,然后再根據所輸入的數字,進入對應的函數實現相應的功能。具體的函數功能可以慢慢的實現,先把框架搭建起來。
def main():#主函數while True:menum()choice=int(input('請選擇:'))if choice in [0,1,2,3,4,5,6,7]:if choice==0:answer=input('您確定要退出系統嗎?y/n')if answer=='y':#print('謝謝您的使用')breakelse :continueelif choice==1:insert()elif choice==2:search()elif choice==3:delete()elif choice==4:modify()elif choice==5:sort()elif choice==6:total()elif choice==7:show()else:print('您輸入的有誤,請重新輸入')main()?
? 五、學生信息維護模式設計
? ? ? ? 1、錄入學生信息功能
? ? ? ? ? ? ? ? 1、1實現錄入學生信息功能
? ? ? ? ? ? ? ? ? ? ? ? 從控制臺錄入學生信息,并且把它們保存到磁盤中
? ? ? ? ? ? ? ? 1、2業務流程
? ? ? ? ? ? ? ? 1、3具體實現?
?
? ? ? ? ? ? ? ? 1、4代碼與結果演示及講解
def insert():#插入student_lst=[]#聲明一個列表,用于存儲學生信息while True:id=input('請輸入id(如1001):')if not id:#如果輸入為空,那么id的值為False,就進入不了循環,所以加一個not即可判斷是否為空breakname=input('請輸入名字(如張三):')if not name:breaktry:english=int(input('請輸入英語成績:'))python = int(input('請輸入python成績:'))java = int(input('請輸入java成績:'))except:print('您輸入的有誤,請重新輸入')continue#將錄入的學生信息保存到字典中student={'id':id,'name':name,'english':english,'python':python,'java':java}student_lst.append(student)answer=input('是否繼續添加?y/n')if answer=='y':continueelse:break#調用save()函數save(student_lst)print('學生信息完畢!!!') def save(lst):try:stu_text=open(filename,'a',encoding='utf-8')#打開文件,以追加的形式except:stu_text=open(filename,'w',encoding='utf-8')#以只寫的形式打開文件for item in lst:stu_text.write(str(item)+'\n')stu_text.close()?
? ? ? ? ? ? ? ? ? ? ? ? ①?先聲明一個列表,用來存儲學生信息
? ? ? ? ? ? ? ? ? ? ? ? ②根據流程,在一個while:True的循環中輸入學生id,為了防止輸入為空,要進行一個判斷是否為空,如果為空,則其bool值為False,所以進行的是not id 判斷;對姓名同樣如此,但是對成績則不一樣,因為成績只能為整數,為了防止用戶輸入錯誤,這里采用異常處理,提示用戶輸入錯誤;然后再將學生的信息保存到字典當中(因為字典是以鍵值對的形式存儲的),然后再將字典中的值添加到最初聲明的列表中;添加之后要保存到磁盤中,這時候就要調用save函數了;
? ? ? ? ? ? ? ? ? ? ? ? ③save進行將數據存入磁盤中,當文件存在時,以追加的形式打開,如果文件不存在則以寫的形式打開存儲到一個變量當中,然后遍歷列表,將數據存入磁盤之中;因為成績是int 型,所以需要進行數據類型轉換
? ? ? ? 2、刪除學生信息功能
? ? ? ? ? ? ? ? 2、1實現刪除學生信息功能
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 從控制臺錄入學生id到磁盤文件中找到對應的學生信息,并將其刪除
? ? ? ? ? ? ? ? 2、2業務流程
? ? ? ? ? ? ? ? 2、3具體實現?
? ? ? ? ? ? ? ? 2、4代碼與結果演示及講解
def delete():while True:student_id=input('請輸入要刪除的學生的ID:')if student_id!='':#輸入的id不為空if os.path.exists(filename):#判斷文件是否存在with open(filename,'r',encoding='utf-8') as file:#打開文件student_old=file.readlines()#讀取所有數據,放到列表當中else:student_old=[]flag=False #標記是否刪除if student_old:#如果列表不空,用只寫的方式打開,將原有類容進行覆蓋with open(filename,'w',encoding='utf-8') as wfile:d={}for item in student_old:#遍歷列表,讀出的是一個字符串d=dict(eval(item))#將字符串轉成字典if d['id']!=student_id:#如果不相等就把其寫入wfile.write(str(d)+'\n')else:#相等就刪除flag=Trueif flag:print(f'id為{student_id}的學生信息以被刪除')else:print(f'沒有找到ID為{student_id}的學生信息')else:print('無學生信息')breakshow() #刪除之后要重新顯示所有學生信息answer=input('是否繼續刪除?y/n')if answer=='y':continueelse:break? ? ? ? ? ? ? ? ? ? ? ????????? ①先輸入學生id,然后判斷其是否為空(因為循環是while:True是一直循環的,當其輸入為空時,無法進入下一步,就會顯示請輸入ID),若不為空,然后再判斷其文件是否存在,如果存在則以只讀的方式打開,放入列表中,若為空,則說明文件中無信息,將列表賦值為空值
???????????????? ? ? ②設一個標識符(判斷是否成功刪除),若列表不為空,以只寫的方式打開文件,然后遍歷列表,將列表中的內容存儲到字典當中,如果字典中的id和要刪除的id不相等則寫入文件,否則不寫入。
注意:此處的刪除不是把文件中的內容刪除,而是通過重新寫入的方式將以前的內容覆蓋掉,如果id相等了就不寫入。
? ? ? ? 3、修改學生信息功能
? ? ? ? ? ? ? ? 3、1實現學生信息修改功能
? ? ? ? ? ? ? ? ? ? ? ? 從控制臺錄入學生id到磁盤文件中找到對應的學生信息,將其進行修改?
? ? ? ? ? ? ? ? 3、2業務流程
? ? ? ? ? ? ? ? 3、3具體實現
? ? ? ? ? ? ? ? ?3、4代碼與結果演示及講解
def modify():show()if os.path.exists(filename):#判斷這個文件是否存在with open(filename,'r',encoding='utf-8') as rfile:student_old=rfile.readlines()#以只讀的形式賦給列表else :returnstudent_id=input('請輸入要修改的學生id:')with open(filename,'w',encoding='utf_8') as wfile:for item in student_old:d=dict(eval(item))if d['id']==student_id:print('找到學生信息,可以修改他的相關信息了!')while True:try:d['name']=input('請輸入姓名:')d['englist']=input('請輸入英語成績:')d['python']=input('請輸入python成績:')d['java']=input('請輸入java成績:')except:print('您的輸入有誤,請重新輸入!!!')else :breakwfile.write(str(d)+'\n')print('修改成功')else:wfile.write(str(d)+'\n')answer=input('是否修改其他學生信息?y/n\n')if answer=='y':modify()?
? ? ? ? ? ? ? ? ? ? ? ? ①修改學生信息之前先把所有的信息展現出來,以防止不知道有哪些信息能更改,show()就是展示函數,但是目前還沒寫。
? ? ? ? ? ? ? ? ? ? ? ? ②輸入學生id以只讀的方式打開文件,然后存到列表中,再遍歷列表判斷是否有id相等的,如果相等則修改(也就是覆蓋操作),如果沒有則正常寫入文件中。
?
六、查詢/統計模塊設計
? ? ? ? 1、查找學生信息功能
? ? ? ? ? ? ? ? 1、1實現查詢學生信息功能
? ? ? ? ? ? ? ? ? ? ? ? 從控制臺錄入學生信息到磁盤文件中查找對應的學生信息
? ? ? ? ? ? ? ??1、2業務流程
? ? ? ? ? ? ? ? ? ? ? ? 1、3具體實現?
? ? ? ? ? ? ? ? ? ? ? ? ?1、4代碼與結果演示及講解
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
def search():student_query=[]#聲明一個列表while True:id=''name=''if os.path.exists(filename):#判斷文件是否存在mode=input('按id查找請輸入1,按姓名查找請輸入2')if mode=='1':id=input('請輸入學生ID:')elif mode=='2':name=input('請輸入學生姓名:')else:print('您的輸入有誤,請重新輸入')search()with open(filename,'r',encoding='utf-8') as rfile:#以只讀的方式打開student=rfile.readlines()#獲取全部的內容存入列表中for item in student:#遍歷列表存入字典中d=dict(eval(item))if id!='':#因為有兩種查詢方式,再加上最開始默認值為0,所以進行判斷用哪種方式if d['id']==id:student_query.append(d)#如果查詢的id在字典中,則將內容添加到新的列表中elif name!='':if d['name']==name:student_query.append(d)#如果查詢到name在字典中,則將內容添加到新的列表中#顯示查詢結果show_student(student_query)#展現新的列表,需要格式化輸出#清空列表student_query.clear()answer=input('是否要繼續查詢?y/n\n')if answer=='y':continueelse:breakelse:print('暫未保存學生信息')return def show_student(lst):if len(lst)==0:print('沒有查詢到學生信息,無數據顯示!!!')return#定義標題的顯示格式format_title='{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'print(format_title.format('ID','姓名','英語成績','python成績','java成績','總成績'))#定義內容的顯示格式format_data='{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'for item in lst:print(format_data.format(item.get('id'),item.get('name'),item.get('englist'),item.get('python'),item.get('java'),int(item.get('englist'))+int(item.get('python'))+int(item.get('java'))))?
? ? ? ? ? ? ? ? ? ? ? ? ? ? ?①首先要聲明一個列表,用來存儲找到的信息
? ? ? ? ? ? ? ? ? ? ? ? ? ? ?②判斷文件是否存在,然后選擇按ID還是名字查詢
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ③?將文件以只讀的模式打開,然后判斷ID或名字是否存在,若存在則存入新的列表中,即最開始聲明的列表中,然后以一個格式化的樣式輸出。
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ④格式化輸出? ?
? ? ? ? 2、統計學生總人數
? ? ? ? ? ? ? ? 2、1實現統計學生總人數功能
? ? ? ? ? ? ? ? ? ? ? ? 統計學生信息文件中保存的學生信息個數?
? ? ? ? ? ? ? ? 2、2業務流程
? ? ? ? ? ? ? ? 2、3具體實現
? ? ? ? ? ? ? ? 2、4?代碼與結果演示及講解
def total():if os.path.exists(filename):#判斷文件是否存在with open(filename,'r',encoding='utf-8') as rfile:#只讀的模式打開文件students=rfile.readlines()#獲取文件中全部內容,存入列表中if students:print(f'一共有{len(students)}名學生')else:print('還沒有錄入學生信息')else:print('暫未保存數據.....')?
? ? 這個思路就相對簡單了,看代碼就可以理解了,就不過多介紹了
? ? ? ? 3、顯示所有學生信息功能
? ? ? ? ? ? ? ? 3、1實現顯示所有學生信息功能
? ? ? ? ? ? ? ? ? ? ? ? 將學生信息文件中保存的全部學生信息獲取并顯示
? ? ? ? ? ? ? ? 3、2業務流程
? ? ? ? ? ? ? ? 3、3具體實現
?
? ? ? ? ? ? ? ? 3、4代碼與結果演示及講解
def show():studetn_lst=[]if os.path.exists(filename):with open(filename,'r',encoding='utf-8') as rfile:students=rfile.readlines()for item in students:studetn_lst.append(eval(item))if studetn_lst:show_student(studetn_lst) def show_student(lst):if len(lst)==0:print('沒有查詢到學生信息,無數據顯示!!!')return#定義標題的顯示格式format_title='{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'print(format_title.format('ID','姓名','英語成績','python成績','java成績','總成績'))#定義內容的顯示格式format_data='{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'for item in lst:print(format_data.format(item.get('id'),item.get('name'),item.get('englist'),item.get('python'),item.get('java'),int(item.get('englist'))+int(item.get('python'))+int(item.get('java'))))?
?這個與查詢學生信息類似,只是少了個判斷的環節,把所有的信息都展現出來
七、排序模塊設計
? ? ? ? 1、排序模塊的設計
? ? ? ? ? ? ? ? 1、1實現按學生成績排序功能
? ? ? ? ? ? ? ? 1、2業務流程
?
? ? ? ? ? ? ? ? 1、3具體實現
? ? ? ? ? ? ? ? ? ?1、4代碼與結果演示及講解
def sort():show()#顯示所有學生信息if os.path.exists(filename):#判斷文件是否存在with open(filename,'r',encoding='utf-8') as rfile:student_list=rfile.readlines()#讀取所有信息student_new = []for item in student_list:#編列列表,存入新的列表中d=dict(eval(item))student_new.append(d)else:returnasc_or_desc=input('請選擇(0,升序 1,降序)')if asc_or_desc=='0':#之所以升序是False是因為python內置函數的原因asc_or_desc_bool=Falseelif asc_or_desc=='1':asc_or_desc_bool=Trueelse:print('您的輸入有誤,請重新輸入')sort()mode=input('請選擇排序方式(1.按英語成績排序 2.按Python成績排序 3.按java成績排序 0.按總成績排序:')if mode=='1':student_new.sort(key=lambda x:int(x['englist']),reverse=asc_or_desc_bool)elif mode=='2':student_new.sort(key=lambda x: int(x['python']), reverse=asc_or_desc_bool)elif mode=='3':student_new.sort(key=lambda x: int(x['java']), reverse=asc_or_desc_bool)elif mode=='0':student_new.sort(key=lambda x: int(x['englist'])+int(x['python'])+int(x['java']), reverse=asc_or_desc_bool)else:print('您輸入有誤,請重新 輸入!!!')sort()show_student(student_new)?八、總結
? ? ? ? 這是用python做的第一個項目,學起來還是有那么點吃力的,主要是對磁盤文件的讀取以及整個的邏輯思維這一塊的問題。把整個項目復盤了一遍后發現其實沒那么難,只是最開始做起來邏輯思維跟知識的運用沒有那么熟練,總結下來之后整體的大致思路以及操作大致掌握清楚,接下來要做的就是鞏固以及熟練掌握。
總結
以上是生活随笔為你收集整理的Python小项目——学生信息管理系统(详细讲解)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 错误的产品设计
- 下一篇: 使用异步Servlet改进应用性能