使用python以及pandas库DataFrame,完成如下的任务。 具体的功能如下: 完成一个与新冠有关的健康记录程序,用于记录、查看家人的身体健康状态,包括: 1、人员的基本信息 每人有且只有一条,基本信息应该有: 人员id,整数,可以从1开始,不能和其他人重复; 人员姓名,字符串; 当前状况,可能是以下的几种状态之一:阴,阳,阳康。可以用整数的不同值来表示,在展示的时候再换成具体的文字信息。也可以直接用上述几个状态的字符串来表示。 2、人员体温血氧监测记录 每人可能有多条不同时间的监测记录,也可能无记录。是否记录,以及多长间隔记录一次由使用者决定。 单条监测记录,应该包括的信息有: 人员id,要与基本信息中的人员id一致(这样才能进行关联); 时间戳,一个整数,可以是1970年到现在经历的秒数,也可以是类似2022122519这样的可直接阅读出时间信息的字符串; 体温,浮点数; 血氧值,整数,0~100间 功能要求: 1、录入功能 录入人员信息,修改人员信息(比如从阴改阳,阳改阳康) 录入体温血氧监测记录 2、查看功能 查看所有人员的基本信息 查看某个人员的所有体温血氧监测记录 查看某个人员的最高体温、最低血氧等 其他你认为可以加上的功能
时间: 2024-04-23 09:24:06 浏览: 17
好的,这是一个很有实际意义的任务,我可以帮你完成。首先,需要导入 pandas 库,并且创建一个 DataFrame,来存储所有人员的信息和监测记录。下面是代码:
```python
import pandas as pd
# 创建人员信息表格
person_info = pd.DataFrame(columns=['id', 'name', 'status'])
# 创建体温血氧监测记录表格
monitor_record = pd.DataFrame(columns=['id', 'timestamp', 'temperature', 'blood_oxygen'])
```
接下来,我们可以实现录入功能。对于人员信息的录入,我们可以通过读取用户的输入来完成。而对于监测记录的录入,我们也可以通过读取用户的输入,并将其添加到 DataFrame 中。下面是代码:
```python
# 录入人员信息
def input_person_info():
while True:
person_id = int(input("请输入人员id:"))
if person_id in person_info['id'].values:
print("该id已存在,请重新输入")
continue
person_name = input("请输入人员姓名:")
person_status = input("请输入人员当前状况(阴、阳、阳康):")
person_info.loc[len(person_info)] = [person_id, person_name, person_status]
print("录入成功")
break
# 录入监测记录
def input_monitor_record():
person_id = int(input("请输入人员id:"))
if person_id not in person_info['id'].values:
print("该id不存在,请重新输入")
return
timestamp = input("请输入时间戳:")
temperature = float(input("请输入体温:"))
blood_oxygen = int(input("请输入血氧值:"))
monitor_record.loc[len(monitor_record)] = [person_id, timestamp, temperature, blood_oxygen]
print("录入成功")
```
接下来,我们可以实现查看功能。具体来说,我们可以通过 DataFrame 的查询功能,来实现查看所有人员的基本信息,以及某个人员的所有监测记录。而查看某个人员的最高体温、最低血氧等信息,我们可以通过 DataFrame 的聚合功能来实现。下面是代码:
```python
# 查看所有人员的基本信息
def view_all_person_info():
print(person_info)
# 查看某个人员的所有监测记录
def view_monitor_record_by_id():
person_id = int(input("请输入人员id:"))
if person_id not in person_info['id'].values:
print("该id不存在,请重新输入")
return
record = monitor_record[monitor_record['id'] == person_id]
print(record)
# 查看某个人员的最高体温、最低血氧等信息
def view_person_info_by_id():
person_id = int(input("请输入人员id:"))
if person_id not in person_info['id'].values:
print("该id不存在,请重新输入")
return
record = monitor_record[monitor_record['id'] == person_id]
print("最高体温:", record['temperature'].max())
print("最低血氧:", record['blood_oxygen'].min())
```
最后,如果你想添加其他功能,可以参考上述代码,并自行实现。