使用python以及pandas库DataFrame,完成如下的任务。 具体的功能如下: 完成一个与新冠有关的健康记录程序,用于记录、查看家人的身体健康状态,包括: 1、人员的基本信息 每人有且只有一条,基本信息应该有: 人员id,整数,可以从1开始,不能和其他人重复; 人员姓名,字符串; 当前状况,可能是以下的几种状态之一:阴,阳,阳康。可以用整数的不同值来表示,在展示的时候再换成具体的文字信息。也可以直接用上述几个状态的字符串来表示。 2、人员体温血氧监测记录 每人可能有多条不同时间的监测记录,也可能无记录。是否记录,以及多长间隔记录一次由使用者决定。 单条监测记录,应该包括的信息有: 人员id,要与基本信息中的人员id一致(这样才能进行关联); 时间戳,一个整数,可以是1970年到现在经历的秒数,也可以是类似2022122519这样的可直接阅读出时间信息的字符串; 体温,浮点数; 血氧值,整数,0~100间 功能要求: 1、录入功能 录入人员信息,修改人员信息(比如从阴改阳,阳改阳康) 录入体温血氧监测记录 2、查看功能 查看所有人员的基本信息 查看某个人员的所有体温血氧监测记录 查看某个人员的最高体温、最低血氧等 其他你认为可以加上的功能
时间: 2024-04-22 11:25:52 浏览: 80
好的,这是一个很有趣的任务。首先我们需要创建一个空的DataFrame,用来存储人员的基本信息和体温血氧监测记录。下面是实现这个程序的代码:
```python
import pandas as pd
# 创建一个空的DataFrame
df = pd.DataFrame(columns=['id', 'name', 'status'])
# 人员基本信息
df.loc[0] = [1, '张三', 0] # id为1,姓名为张三,状态为阴
# 体温血氧监测记录
df_monitor = pd.DataFrame(columns=['id', 'timestamp', 'temperature', 'blood_oxygen'])
# 录入功能
def add_person():
id = int(input("请输入人员id:"))
name = input("请输入人员姓名:")
status = int(input("请输入人员当前状况(阴=0,阳=1,阳康=2):"))
df.loc[len(df)] = [id, name, status]
def edit_person():
id = int(input("请输入要修改的人员id:"))
status = int(input("请输入新的人员状态(阴=0,阳=1,阳康=2):"))
df.loc[df['id'] == id, 'status'] = status
def add_monitor_record():
id = int(input("请输入人员id:"))
timestamp = input("请输入监测时间戳:")
temperature = float(input("请输入体温:"))
blood_oxygen = int(input("请输入血氧值:"))
df_monitor.loc[len(df_monitor)] = [id, timestamp, temperature, blood_oxygen]
# 查看功能
def view_all_person():
print(df)
def view_person_monitor():
id = int(input("请输入要查看的人员id:"))
df_temp = df_monitor.loc[df_monitor['id'] == id]
print(df_temp)
def view_person_stat():
id = int(input("请输入要查看的人员id:"))
df_temp = df_monitor.loc[df_monitor['id'] == id]
max_temperature = df_temp['temperature'].max()
min_blood_oxygen = df_temp['blood_oxygen'].min()
print("最高体温:{}".format(max_temperature))
print("最低血氧:{}".format(min_blood_oxygen))
# 主程序
while True:
print("请选择要执行的操作:")
print("1、录入人员信息")
print("2、修改人员信息")
print("3、录入体温血氧监测记录")
print("4、查看所有人员的基本信息")
print("5、查看某个人员的所有体温血氧监测记录")
print("6、查看某个人员的最高体温、最低血氧等")
print("7、退出程序")
choice = input()
if choice == '1':
add_person()
elif choice == '2':
edit_person()
elif choice == '3':
add_monitor_record()
elif choice == '4':
view_all_person()
elif choice == '5':
view_person_monitor()
elif choice == '6':
view_person_stat()
elif choice == '7':
break
else:
print("输入错误,请重新输入!")
```
以上程序中,我们使用了pandas库的DataFrame数据结构来存储人员的基本信息和体温血氧监测记录。录入功能包括录入人员信息和录入体温血氧监测记录两部分。查看功能包括查看所有人员的基本信息、查看某个人员的所有体温血氧监测记录、查看某个人员的最高体温、最低血氧等。
阅读全文