• Python搭的学生信息管理系统


    1. import os.path
    2. filename='student.txt'
    3. def main():
    4. while True:
    5. menu()
    6. choice=int(input('请输入您要用的功能'))
    7. if choice in [0,1,2,3,4,5,6,7]:
    8. if choice==0:
    9. answer=input('您确定要退出系统吗?')
    10. if answer=='y' or answer=='Y':
    11. print('谢谢您的使用')
    12. break
    13. else:
    14. continue
    15. elif choice==1:
    16. insert()
    17. elif choice==2:
    18. search()
    19. elif choice==3:
    20. delete()
    21. elif choice==4:
    22. modify()
    23. elif choice==5:
    24. sort()
    25. elif choice==6:
    26. total()
    27. elif choice==7:
    28. show()
    29. def menu():
    30. print('------------------------学生信息管理系统----------------------------------')
    31. print('-------------------------功能菜单---------------------------------------')
    32. print('\t\t\t\t1.录入学生信息')
    33. print('\t\t\t\t2.查找学生信息')
    34. print('\t\t\t\t3.删除学生信息')
    35. print('\t\t\t\t4.修改学生信息')
    36. print('\t\t\t\t5.排序')
    37. print('\t\t\t\t6.统计学生总人数')
    38. print('\t\t\t\t7.显示所有学生信息')
    39. print('\t\t\t\t0.退出系统')
    40. print('-------------------------------------------------------------------------')
    41. def insert():
    42. student_list=[]
    43. while True:
    44. id=input('请输入id:')
    45. if not id:
    46. break
    47. name=input('请输入姓名:')
    48. if not name:
    49. break
    50. try:
    51. english=int(input('请输入英语成绩:'))
    52. python=int(input('请输入python成绩:'))
    53. java=int(input('请输入java成绩:'))
    54. except:
    55. print('输入无效,不是整数类型,请重新输入')
    56. #将录入的学生信息保存到字典中
    57. student={'id':id,'name':name,'english':english,'python':python,'java':java}
    58. #将学生信息添加到列表中
    59. student_list.append(student)
    60. answer=input('是否继续添加?y/n\n')
    61. if answer=='y' or answer=='Y':
    62. continue
    63. else:
    64. break
    65. save(student_list)
    66. print('学生信息录入完毕')
    67. def save(lst):
    68. try:
    69. stu_txt=open(filename,'a',encoding='utf-8')
    70. except:
    71. stu_txt=open(filename,'w',encoding='utf-8')
    72. for item in lst:
    73. stu_txt.write(str(item)+'\n')
    74. stu_txt.close()
    75. def search():
    76. student_query=[]
    77. while True:
    78. id=''
    79. name=''
    80. if os.path.exists(filename):
    81. mode=input('按ID查找请输入1,按姓名查找请输入2:')
    82. if mode=='1':
    83. id=input('请输入学生ID')
    84. elif mode=='2':
    85. name=input('请输入学生姓名:')
    86. else:
    87. print('您的输入有误,请重新输入')
    88. search()
    89. with open(filename,'r',encoding='utf-8') as rfile:
    90. student=rfile.readlines()
    91. for item in student:
    92. d=dict(eval(item))
    93. if id!='':
    94. if d['id']==id:
    95. student_query.append(d)
    96. elif name!='':
    97. if d['name']==name:
    98. student_query.append(d)
    99. #显示查询结果
    100. show_student(student_query)
    101. #清空列表
    102. student_query.clear()
    103. answer=input('是否要继续查询?y/n\n')
    104. if answer=='y' or answer=='Y':
    105. continue
    106. else:
    107. break
    108. else:
    109. print('暂未保存学生信息')
    110. return
    111. def show_student(lst):
    112. if len(lst)=='':
    113. print('没有查询到学生信息,无数据显示!!!')
    114. return
    115. #定义标题显示格式
    116. format_title='{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}'
    117. print(format_title.format('ID','姓名','英语成绩','Python成绩','Java成绩','总成绩'))
    118. #定义内容的显示格式
    119. format_data='{:^6}\t{:^12}\t{:^8}\t{:^8}\t{:^8}\t{:^8}'
    120. for item in lst:
    121. print(format_data.format(item.get('id'),
    122. item.get('name'),
    123. item.get('english'),
    124. item.get('python'),
    125. item.get('java'),
    126. int(item.get('english'))+int(item.get('python'))+int(item.get('java'))
    127. ))
    128. def delete():
    129. while True:
    130. student_id=input('请输入要删除的学生的ID:')
    131. if student_id!='':
    132. if os.path.exists(filename):
    133. with open(filename,'r',encoding='utf-8') as file:
    134. student_old=file.readlines()
    135. else:
    136. student_old=[]
    137. flag=False #标记是否删除
    138. if student_old:
    139. with open(filename,'w',encoding='utf-8') as wfile:
    140. d={}
    141. for item in student_old:
    142. d=dict(eval(item)) #将字符串转成字典
    143. if d['id']!=student_id:
    144. wfile.write(str(d)+'\n')
    145. else:
    146. flag=True
    147. if flag:
    148. print(f'id未{student_id}的学生信息已被删除')
    149. else:
    150. print(f'没有找到ID为{student_id}的学生信息')
    151. else:
    152. print('无学生信息')
    153. break
    154. show()
    155. answer=input('是否继续删除?y/n\n')
    156. if answer=='y' or answer=='Y':
    157. continue
    158. else:
    159. break
    160. def modify():
    161. show()
    162. if os.path.exists(filename):
    163. with open(filename,'r',encoding='utf-8') as rfile:
    164. student_old=rfile.readlines()
    165. else:
    166. return
    167. student_id=input('请输入要修改的学员的ID:')
    168. with open(filename,'w',encoding='utf-8') as wfile:
    169. for item in student_old:
    170. d=dict(eval(item))
    171. if d['id']==student_id:
    172. print('找到学生信息,可以修改他的相关信息!')
    173. while True:
    174. try:
    175. d['name']=input('请输入姓名:')
    176. d['english']=input('请输入英语成绩:')
    177. d['python']=input('请输入python成绩:')
    178. d['java']=input('请输入java成绩:')
    179. except:
    180. print('您的输入有误,请重新输入!')
    181. else:
    182. break
    183. wfile.write(str(d)+'\n')
    184. print('修改成功!!!')
    185. else:
    186. wfile.write(str(d)+'\n')
    187. answer=input('是否继续修改其他学生信息?y/n\n')
    188. if answer=='y' or answer=='Y':
    189. modify()
    190. def sort():
    191. show()
    192. if os.path.exists(filename):
    193. with open(filename,'r',encoding='utf-8') as rfile:
    194. student_list=rfile.readlines()
    195. student_new=[]
    196. for item in student_list:
    197. d=dict(eval(item))
    198. student_new.append(d)
    199. else:
    200. return
    201. asc_or_desc=input('请选择(0.升序 1.降序):')
    202. if asc_or_desc=='0':
    203. asc_or_desc_bool=False
    204. elif asc_or_desc=='1':
    205. asc_or_desc_bool=True
    206. else:
    207. print('您输入的有误,请重新输入')
    208. sort()
    209. mode=input('请选择排序方式(1.按英语成绩排序 2.按Python成绩牌序 3.按Java成绩牌序 0.按总成绩排序):')
    210. if mode=='1':
    211. student_new.sort(key=lambda x :int(x['english']),reverse=asc_or_desc_bool)
    212. elif mode=='2':
    213. student_new.sort(key=lambda x: int(x['python']),reverse=asc_or_desc_bool)
    214. elif mode=='3':
    215. student_new.sort(key=lambda x: int(x['java']),reverse=asc_or_desc_bool)
    216. elif mode=='0':
    217. student_new.sort(key=lambda x: int(x['english'])+int(x['python'])+ int(x['java']),reverse=asc_or_desc_bool)
    218. else:
    219. print('您输入的有误,请重新输入!!!')
    220. sort()
    221. show_student(student_new)
    222. def total():
    223. if os.path.exists(filename):
    224. with open(filename,'r',encoding='utf-8') as rfile:
    225. students=rfile.readlines()
    226. if students:
    227. print(f'一共有{len(students)}名学生')
    228. else:
    229. print('还没有录入学生信息')
    230. else:
    231. print('暂未保存数据信息')
    232. def show():
    233. student_list=[]
    234. if os.path.exists(filename):
    235. with open(filename,'r',encoding='utf-8') as rfile:
    236. students=rfile.readlines()
    237. for item in students:
    238. student_list.append(eval(item))
    239. if student_list:
    240. show_student(student_list)
    241. else:
    242. print('暂未保存数据信息!')
    243. if __name__ == '__main__':
    244. main()

  • 相关阅读:
    大端模式与小端模式
    sql聚合函数嵌套问题 aggregate function cannot contain aggregate parameters
    虹科案例 | 虹科HiveMQ助力实现百万辆汽车智能互联
    GIT命令
    Kotlin jetpack compose Tab的渲染 AnimatedVisibility的使用
    【操作系统】模块四:进程和线程
    禅道登录-调用API方式
    探究eFuse:硬件保障与系统安全的核心
    redis数据一致性问题还稀里糊涂?看这篇就够了
    python操作excel中xlrd模块的一些简单方法
  • 原文地址:https://blog.csdn.net/qq_50377269/article/details/133561290