服务器之家

服务器之家 > 正文

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

时间:2021-08-19 00:39     来源/作者:Miku丨无形

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

下面直接上代码

增加职工数据

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
# 接收用户收入
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()

删除职工数据

?
1
2
3
4
5
6
7
8
9
id = input('请输入你要修改的职工编号')
ids = [i[0] for i in data]
if id not in ids:
  print('您查询的职工不存在')
  return
else:
  del data[ids.index(id)]
  print('删除成功')
save()

查询职工数据

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
# 选择查询目标
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()

修改职工信息

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
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()

排序函数

?
1
2
global data
data = sorted(data, key=lambda x: x[1])

统计函数

?
1
2
3
4
5
6
7
8
9
10
11
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))

显示函数

?
1
2
3
4
5
6
7
# 打印标题
print('职工号 姓名 性别 年龄 学历 住址 电话 工资')
# 遍历数据列表 然后打印数据
for i in data:
 for j in i:
   print(j, end=' ')
 print()

读取保存函数

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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()

总结整体代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
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 职工信息管理系统内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/Miku_wx/article/details/111796704

相关文章

热门资讯

yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
2021德云社封箱演出完整版 2021年德云社封箱演出在线看
2021德云社封箱演出完整版 2021年德云社封箱演出在线看 2021-03-15
返回顶部