用Python实现职工信息管理系统


Posted in Python onDecember 30, 2020

想要实现一个职工管理系统
首先我们看一下想要实现什么功能
最基础的增删改查肯定要实现的
然后增加一下数据显示、数据排序、数据统计功能

下面直接上代码

增加职工数据

# 接收用户收入
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

到此这篇关于用Python实现职工信息管理系统的文章就介绍到这了,更多相关Python 职工信息管理系统内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python实现批量转换文件编码(批转换编码示例)
Jan 23 Python
Flask框架学习笔记(一)安装篇(windows安装与centos安装)
Jun 25 Python
解决python爬虫中有中文的url问题
May 11 Python
Python3删除排序数组中重复项的方法分析
Jan 31 Python
详解Python中的内建函数,可迭代对象,迭代器
Apr 29 Python
Python Pandas 获取列匹配特定值的行的索引问题
Jul 01 Python
Django使用模板后无法找到静态资源文件问题解决
Jul 19 Python
pymysql 开启调试模式的实现
Sep 24 Python
python实现指定ip端口扫描方式
Dec 17 Python
python3实现往mysql中插入datetime类型的数据
Mar 02 Python
python中的django是做什么的
Jul 31 Python
python 使用pandas读取csv文件的方法
Dec 24 Python
python实现双人五子棋(终端版)
Dec 30 #Python
pandas 数据类型转换的实现
Dec 29 #Python
python中xlutils库用法浅析
Dec 29 #Python
Python操作PostgreSql数据库的方法(基本的增删改查)
Dec 29 #Python
python中uuid模块实例浅析
Dec 29 #Python
python中pickle模块浅析
Dec 29 #Python
vue.js刷新当前页面的实例讲解
Dec 29 #Python
You might like
教你如何使用php session
2013/10/28 PHP
ThinkPHP3.1新特性之多数据库操作更加完善
2014/06/19 PHP
php获取apk包信息的方法
2014/08/15 PHP
Jquery知识点二 jquery下对数组的操作
2011/01/15 Javascript
jQuery事件绑定和委托实例
2014/11/25 Javascript
JavaScript定时器和优化的取消定时器方法
2015/07/03 Javascript
如何根据百度地图计算出两地之间的驾驶距离(两种语言js和C#)
2015/10/29 Javascript
浅谈javascript 函数表达式和函数声明的区别
2016/01/05 Javascript
JS实现响应鼠标点击动画渐变弹出层效果代码
2016/03/25 Javascript
js操作DOM--添加、删除节点的简单实例
2016/07/08 Javascript
js原生实现FastClick事件的实例
2016/11/20 Javascript
js移动焦点到最后位置的简单方法
2016/11/25 Javascript
jQuery实现级联下拉框实战(5)
2017/02/08 Javascript
使用vue框架 Ajax获取数据列表并用BootStrap显示出来
2017/04/24 Javascript
基于Bootstrap分页的实例讲解(必看篇)
2017/07/04 Javascript
详解如何在react中搭建d3力导向图
2018/01/12 Javascript
详解vue-cli 构建项目 vue-cli请求后台接口 vue-cli使用axios、sass、swiper
2018/05/28 Javascript
微信小程序发布新版本时自动提示用户更新的方法
2019/06/07 Javascript
Layui数据表格判断编辑输入的值,是否为我需要的类型详解
2019/10/26 Javascript
JavaScript oncopy事件用法实例解析
2020/05/13 Javascript
python检查字符串是否是正确ISBN的方法
2015/07/11 Python
使用apidoc管理RESTful风格Flask项目接口文档方法
2018/02/07 Python
简单了解python PEP的一些知识
2019/07/13 Python
python点击鼠标获取坐标(Graphics)
2019/08/10 Python
Python列表删除元素del、pop()和remove()的区别小结
2019/09/11 Python
python requests模拟登陆github的实现方法
2019/12/26 Python
解决TensorFlow训练内存不断增长,进程被杀死问题
2020/02/05 Python
用Python绘制漫步图实例讲解
2020/02/26 Python
h5页面唤起app如果没安装就跳转下载(iOS和Android)
2020/06/03 HTML / CSS
DOUGLAS荷兰:购买香水和化妆品
2020/10/24 全球购物
宿舍打麻将检讨书
2014/01/24 职场文书
校企合作协议书
2014/04/16 职场文书
产品陈列协议书(标准版)
2014/09/17 职场文书
单位综合评价意见
2015/06/05 职场文书
MySQL数据库中的锁、解锁以及删除事务
2022/05/06 MySQL
让JavaScript代码更加精简的方法技巧
2022/06/01 Javascript