用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读取Android permission文件
Nov 01 Python
python批量提交沙箱问题实例
Oct 08 Python
跟老齐学Python之大话题小函数(2)
Oct 10 Python
浅谈python 四种数值类型(int,long,float,complex)
Jun 08 Python
Python使用openpyxl读写excel文件的方法
Jun 30 Python
Python+Turtle动态绘制一棵树实例分享
Jan 16 Python
Python中pandas模块DataFrame创建方法示例
Jun 20 Python
使用Python获取网段IP个数以及地址清单的方法
Nov 01 Python
scrapy-redis源码分析之发送POST请求详解
May 15 Python
python算法与数据结构之单链表的实现代码
Jun 27 Python
opencv python 图像轮廓/检测轮廓/绘制轮廓的方法
Jul 03 Python
编写python代码实现简单抽奖器
Oct 20 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
一个更简单的无限级分类菜单代码
2007/01/16 PHP
PHP中用header图片地址 简单隐藏图片源地址
2008/04/09 PHP
Yii使用ajax验证显示错误messagebox的解决方法
2014/12/03 PHP
php文件操作相关类实例
2015/06/18 PHP
PHP函数实现从一个文本字符串中提取关键字的方法
2015/07/01 PHP
PHP的简单跳转提示的实现详解
2019/03/14 PHP
理解JavaScript中的事件
2006/09/23 Javascript
JavaScript 封装Ajax传递的数据代码
2009/06/05 Javascript
JavaScript定义类或函数的几种方式小结
2011/01/09 Javascript
容易被忽略的JS脚本特性
2011/09/13 Javascript
分享8款优秀的 jQuery 加载动画和进度条插件
2012/10/24 Javascript
js实现连个数字相加而不是拼接的方法
2014/02/23 Javascript
JavaScript中Boolean对象的属性解析
2015/10/21 Javascript
Angularjs通过指令监听ng-repeat渲染完成后执行脚本的方法
2016/12/31 Javascript
nodejs密码加密中生成随机数的实例代码
2017/07/17 NodeJs
JS实现调用本地摄像头功能示例
2018/05/18 Javascript
vue-cli3全面配置详解
2018/11/14 Javascript
一次Webpack配置文件的分离实战记录
2018/11/30 Javascript
Vue组件通信中非父子组件传值知识点总结
2019/12/05 Javascript
python多进程中的内存复制(实例讲解)
2018/01/05 Python
Python中实例化class的执行顺序示例详解
2018/10/14 Python
python 根据时间来生成唯一的字符串方法
2019/01/14 Python
如何使用Python自动控制windows桌面
2019/07/11 Python
基于python实现FTP文件上传与下载操作(ftp&amp;sftp协议)
2020/04/01 Python
Python实现Keras搭建神经网络训练分类模型教程
2020/06/12 Python
萌新的HTML5 入门指南
2020/11/06 HTML / CSS
Photobook澳大利亚:制作相片书,婚礼卡,旅行相簿
2017/01/12 全球购物
人事部主管岗位职责
2013/12/26 职场文书
大学生职业规划范文:象牙塔生活的四年计划
2014/01/14 职场文书
讲座主持词
2014/03/20 职场文书
医药公司开票员岗位职责
2015/04/15 职场文书
初中数学课堂教学反思
2016/02/17 职场文书
《鲸》教学反思
2016/02/23 职场文书
CSS3中Animation实现简单的手指点击动画的示例
2021/07/15 HTML / CSS
《金肉人》米特&《航海王》阿鹤声优松岛实因胰脏癌去世 享寿81岁
2022/04/13 日漫
Pytorch中expand()的使用(扩展某个维度)
2022/07/15 Python