首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

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

想要实现一个职工管理系统

首先我们看一下想要实现什么功能

最基础的增删改查肯定要实现的

然后增加一下数据显示、数据排序、数据统计功能

下面直接上代码

1. 增加职工数据

```python

# 接收用户收入

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()

```

2. 删除职工数据

```python

id = input('请输入你要修改的职工编号')

ids = [i[0] for i in data]

if id not in ids:

print('您查询的职工不存在')

return

else:

del data[ids.index(id)]

print('删除成功')

save()

```

3. 查询职工数据

```python

# 选择查询目标

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()

```

4. 修改职工信息

```python

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()

```

)

5. 排序函数

```python

global data

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

```

6. 统计函数

```python

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(''.format(money, count))

print('工资最多的是:', max(counts))

print('工资最少的是:', min(counts))

```

7. 显示函数

```python

# 打印标题

print('职工号 姓名 性别 年龄 学历 住址 电话 工资')

# 遍历数据列表 然后打印数据

for i in data:

for j in i:

print(j, end=' ')

print()

```

8. 读取保存函数

```python

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()

```

总结整体代码:

```python

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(''.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

```

如果有问题 评论解答

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20201228A0BMOO00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券
http://www.vxiaotou.com