CRUD,每个程序员都必须掌握的
录入C create
def save(lst):#保存信息
try: #保存成绩时有可能出错,所以使用try-except
stu_txt=open(filename,'a',encoding='utf-8')
#filename是个变量,所以不用写单引号
#文件以追加模式打开
#怕中文乱码,所以加上encoding='utf-8'
except:#出错:没有该文件的话就以写入的方式来打开
stu_txt=open(filename,'w',encoding='utf-8')
for item in lst: #可迭代对象,逐个写入
stu_txt.write(str(item)+'\n') #保存到文本文件,要转换成str类型
stu_txt.close() #使用完要关闭资源
def insert():
student_list=[]
while True:
id = int(input("请输入学号如10101"))
if not id:
break
try:
chinese=int (input("请输入语文成绩"))
java= int (input("请输入java成绩"))
python=int (input("请输入python成绩"))
except:
print('成绩输入无效,请输入整数')
continue
student={'id':id,'name':name,'chinese':chinese,'java':java,'python':python} #建立字典,有点像结构体
student_list.append(student)
answer=input('是否需要继续输入\n')
if answer=='y' or answer=='Y':
continue
else:
break
save(student_list)
print("录入完毕!!")
删除D delete
def delete(): #删除学生信息
while True:
student_id=input('请输入要删除的学生的ID:')
if student_id!='': #if student_id!=''与if not student_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)) #将字符串转换成字典
#eval()函数用于执行一个字符串表达式,并且返回该表达式的值
if d['id']!=student_id:
wfile.write(str(d)+'\n') #删除完的字典写进磁盘文件中.写入文本时要转换成str类型
#删除信息-->用一个新字典(没有要删除学生信息)覆盖原有字典,所以写新字典时,如果遇到要删除的信息就不写入新字典
else:
flag=True #如果有相等的,就表示已经删除了,因为没写入到新字典中,设置标记为已删除
if flag:
print(f'id为{student_id}的学生信息已被删除')
else:
print(f'没有找到ID为{student_id}的学生信息')
else: #磁盘上没有数据(一条数据也没有)
print('无学生信息')
break
show() #删除之后要重新显示所有学生信息
answer=input('是否继续删除?y/b\n')
if answer=='y':
continue
else:
break
修改U update
#修改学生信息
def modify():
show()
if os.path.exists(filename):#首先判断文件是否存在
with open(filename,'r',encoding='utf-8') as rfile:
student_old=rfile.readlines()
else:
return
student_id=input('请输入要修改的学员的ID:')
with open(filename,'w',encoding='utf-8') as wfile:
for item in student_old:#对于文件中的每一个内容
d=dict(eval((item)))#读取到的是字符串,用eval函数进行转换,转换成字典类型
if d['id']==student_id:#只有找到信息才可以修改
print('找到学生信息,可以修改他的相关信息了!')
while True:
try:#修改的过程有可能出错,所以使用try-except
d['name']=input('请输入姓名:')
d['englist'] = input('请输入英语成绩:')
d['python'] = input('请输入Python成绩:')
d['java'] = input('请输入Java成绩:')
except:#输入有误就会循环while True
print('您的输入有误,请重新输入!!!')
else:#没有错误就执行else,退出循环
break
wfile.write(str(d)+'\n')#修改完之后再写进文件中(现在是只修改了拿出来的字典的内容)
print('修改成功!!!')
else:
wfile.write(str(d)+'\n')#不需要修改的学生信息继续写入文件
answer=input('是否继续修改其他学生信息?y/n\n')
if answer=='y':
modify()#在函数中写while True,符合条件的一直循环,相当于在条件允许的情况下函数调用自身
查找、读取 R read
{0:^30}
0是一个序号,表示格式化输出的第0个字符,依次累加;
30表示输出宽度约束为30个字符;
^表示输出时右对齐,若宽度小于字符串的实际宽度,以实际宽度输出;
#查找学生信息
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!='':#如果ID不为空
if d['id']==id:
student_query.append(d)
elif name!='':#如果姓名不为空
if d['name']==name:
student_query.append(d)
#显示查询结果
show_student(student_query)
#清空列表
student_query.clear()#下次执行search()之前清空列表
anwser=input('是否要继续查询?y/n\n')
if anwser=='y':
continue
else:
break
else:#文件不存在
print('暂未保存学生信息')
return
#显示指定学生信息
def show_student(lst):
if len(lst)==0:
print('没有查询到学生信息,无数据显示!!!')
return
#定义标题显示格式
format_title='{:^6}\t{:^12}\t{:^4}\t{:^9}\t{:^5}\t{:^5}'#{:^4}表示输出宽度约束为4个字符,右对齐;
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'),#字典可以用get方法,也可以使用方括号
item.get('name'),
item.get('englist'),
item.get('python'),
item.get('java'),
int(item.get('englist'))+int(item.get('python'))+int(item.get('java'))
))
统计学生总人数
#统计学生总人数(判断列表长度)
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('暂未保存数据信息....')
显示所有学生信息
#显示所有学生信息
def show():
student_lst=[]
if os.path.exists(filename):
with open(filename,'r',encoding='utf-8') as rfile:
students=rfile.readlines()
for item in students:
student_lst.append(eval(item))
if student_lst:
show_student(student_lst)
else:
print('暂未保存过数据!!!')
排序模块
lamada表达式:
add = lambda x, y: x + y
print(add(3, 5))
# Output: 8
排序
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:
return
asc_or_desc=input('请选择(0.升序 1.降序)')
if asc_or_desc=='0':
asc_or_desc_bool=False
elif asc_or_desc=='1':
asc_or_desc_bool=True
else:
print('您的输入有误,请重新输入')
sort()#如有错误就调用自身
mode=input('请选择排序方式(1.按英语成绩排序 2.按Python成绩排序 3.按Java成绩排序 4.按总成绩排序)')
if mode=='1':
student_new.sort(key=lambda x:int(x['englist']),reverse=asc_or_desc_bool)
#x这个参数是一个字典,根据参数求值,做类型转换后排序
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=='4':
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)#排序结束之后再显示一遍
项目打包
(-cmd中) 输入 pyinstaller -F 内存地址+文件名
Appending:打包文件的新内存地址(记得把原来的文本文件复制过来)
-F的意思是只剩成一个扩展名为.exe的可执行文件
结果可以得到exe文件的位置
找到文件位置
把txt文件复制到此目录下
双击可以打开
注意事项
项目代码
见资源绑定。