想要实现一个职工管理系统
首先我们看一下想要实现什么功能
最基础的增删改查肯定要实现的
然后增加一下数据显示、数据排序、数据统计功能
下面直接上代码
增加职工数据
# 接收用户收入 id = input('请输入职工号') name = input('请输入姓名') sex = input('请输入性别') age = input('请输入年龄') education = input('请输入学历') address = input('请输入住址') photonumber = input('请输入电话') money = input('请输入工资') # 向列表中添加数据 data.append([id, name, sex, age, education, address, photonumber, money]) print('添加成功') # 调用保存函数 保存数据 save()
删除职工数据
id = input('请输入你要修改的职工编号') ids = [i[0] for i in data] if id not in ids: print('您查询的职工不存在') return else: del data[ids.index(id)] print('删除成功') save()
查询职工数据
# 选择查询目标 flag = int(input('1.按照职工编号查询 2.按照职工姓名查询')) if flag == 1: id = input('输入职工编号') # 职工编号列表 ids = [i[0] for i in data] # 判断输入的编号是否存在 if id not in ids: print('您查询的职工不存在') return else: print('职工号 姓名 性别 年龄 学历 住址 电话 工资') # 打印该编号的信息 for i in data[ids.index(id)]: print(i, end=' ') print() else: name = input('输入职工姓名') # 职工姓名列表 names = [i[1] for i in data] # 判断输入的姓名是否存在 if name not in names: print('您查询的职工不存在') return else: print('职工号 姓名 性别 年龄 学历 住址 电话 工资') # 同上 for i in data[names.index(name)]: print(i, end=' ') print()
修改职工信息
id = input('请输入你要修改的职工编号') ids = [i[0] for i in data] if id not in ids: print('您查询的职工不存在') return else: # 输入要修改的数据 name = input('请输入姓名') sex = input('请输入性别') age = input('请输入年龄') education = input('请输入学历') address = input('请输入住址') photonumber = input('请输入电话') money = input('请输入工资') # 修改数据 data[ids.index(id)] = [id, name, sex, age, education, address, photonumber, money] print('修改成功') save()
排序函数
global data data = sorted(data, key=lambda x: x[1])
统计函数
counts = {} # 统计每个工资的人数 for i in data: counts[int(i[-1])] = counts.get(i[-1], 0) + 1 # 按照人数多少排序 counts = dict(sorted(counts.items(), key=lambda x: x[1], reverse=True)) # 将结果打印 for money, count in counts.items(): print('{0:<10}{1:>5}'.format(money, count)) print('工资最多的是:', max(counts)) print('工资最少的是:', min(counts))
显示函数
# 打印标题 print('职工号 姓名 性别 年龄 学历 住址 电话 工资') # 遍历数据列表 然后打印数据 for i in data: for j in i: print(j, end=' ') print()
读取保存函数
def save(): # 保存函数 # 打开文件,写入数据 with open('数据.csv','w') as j: for i in data: j.write(','.join(i)+'\n') j.close() def load(): # 读取函数 # 读取文件 with open('数据.csv','r') as j: # 读取每行数据 for i in j.readlines(): # 清洗掉换行符 然后以逗号为间隔符分割 data.append(i.replace('\n','').split(',')) j.close()
总结整体代码:
def add(): # 添加数据函数 # 接收用户收入 id = input('请输入职工号') name = input('请输入姓名') sex = input('请输入性别') age = input('请输入年龄') education = input('请输入学历') address = input('请输入住址') photonumber = input('请输入电话') money = input('请输入工资') # 向列表中添加数据 data.append([id, name, sex, age, education, address, photonumber, money]) print('添加成功') # 调用保存函数 保存数据 save() def show(): # 显示函数 # 打印标题 print('职工号 姓名 性别 年龄 学历 住址 电话 工资') # 遍历数据列表 然后打印数据 for i in data: for j in i: print(j, end=' ') print() def quety(): # 查询函数 # 选择查询目标 flag = int(input('1.按照职工编号查询 2.按照职工姓名查询')) if flag == 1: id = input('输入职工编号') # 职工编号列表 ids = [i[0] for i in data] # 判断输入的编号是否存在 if id not in ids: print('您查询的职工不存在') return else: print('职工号 姓名 性别 年龄 学历 住址 电话 工资') # 打印该编号的信息 for i in data[ids.index(id)]: print(i, end=' ') print() else: name = input('输入职工姓名') # 职工姓名列表 names = [i[1] for i in data] # 判断输入的姓名是否存在 if name not in names: print('您查询的职工不存在') return else: print('职工号 姓名 性别 年龄 学历 住址 电话 工资') # 同上 for i in data[names.index(name)]: print(i, end=' ') print() def modify(): # 修改函数 # 原理同上 id = input('请输入你要修改的职工编号') ids = [i[0] for i in data] if id not in ids: print('您查询的职工不存在') return else: # 输入要修改的数据 name = input('请输入姓名') sex = input('请输入性别') age = input('请输入年龄') education = input('请输入学历') address = input('请输入住址') photonumber = input('请输入电话') money = input('请输入工资') # 修改数据 data[ids.index(id)] = [id, name, sex, age, education, address, photonumber, money] print('修改成功') save() def sort(): # 排序函数 global data data = sorted(data, key=lambda x: x[1]) def statistics(): # 统计函数 counts = {} # 统计每个工资的人数 for i in data: counts[int(i[-1])] = counts.get(i[-1], 0) + 1 # 按照人数多少排序 counts = dict(sorted(counts.items(), key=lambda x: x[1], reverse=True)) # 将结果打印 for money, count in counts.items(): print('{0:<10}{1:>5}'.format(money, count)) print('工资最多的是:', max(counts)) print('工资最少的是:', min(counts)) def delete(): # 删除函数 # 原理同上 id = input('请输入你要修改的职工编号') ids = [i[0] for i in data] if id not in ids: print('您查询的职工不存在') return else: del data[ids.index(id)] print('删除成功') save() def save(): # 保存函数 # 打开文件,写入数据 with open('数据.csv','w') as j: for i in data: j.write(','.join(i)+'\n') j.close() def load(): # 读取函数 # 读取文件 with open('数据.csv','r') as j: # 读取每行数据 for i in j.readlines(): # 清洗掉换行符 然后以逗号为间隔符分割 data.append(i.replace('\n','').split(',')) j.close() if __name__ == '__main__': data = [] # 数据保存列表 # 读取文件 如果文件不存在 报错跳过 无视 try: load() except FileNotFoundError: pass while True: # 根据玩家的输入 选择相应的功能 choice = int(input('1.添加职工数据\n2.显示职工数据\n3.查询职工数据\n4.修改职工数据\n5.删除职工数据\n6.保存职工数据\n7.排序职工数据\n8.统计职工工资数据\n9.退出')) if choice == 1: add() elif choice == 2: show() elif choice == 3: quety() elif choice == 4: modify() elif choice == 5: delete() elif choice == 6: save() elif choice == 7: sort() elif choice == 8: statistics() elif choice == 9: print('退出程序') break
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月23日
2024年11月23日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]