'app_account_number', 'juese'=>'app_user_data', 'vitalcapacity'=>'app_card_vitalcapacity_data', 'biaozhun'=>'pc_vitalcapacity_standard', ]; protected $color = ['无效'=>'#FF5656','不及格'=>'#FF5656','及格'=>'#FFAB00','良好'=>'#5AD06D','优秀'=>'#6492F6','牛逼'=>'#3967D6']; protected $curve_data_format = ['one_val'=>['第一次','容积/ml','#009DFF'],'two_val'=>['第二次','容积/ml','#009DFF'],'three_val'=>['第三次','容积/ml','#009DFF'],'average_val'=>['平均','容积/ml','#009DFF']]; protected $pagesize = 15; // 加 bcadd(,,20) // 减 bcsub(,,20) // 乘 bcmul(,,20) // 除 bcdiv(,,20) // 测试token=>'caadd1be045a65f30b92aa805f1de54a' ################################################################接口################################################################ ################################################################接口################################################################ ################################################################接口################################################################ // 手动记录 public function manual_record(){ try { $data = input('post.'); if(!array_key_exists('aud_id', $data) || !array_key_exists('one', $data) || !array_key_exists('two', $data) || !array_key_exists('three', $data) || !array_key_exists('time', $data) || !array_key_exists('token', $data)){ return $this->msg(10001); } unset($data['token']); if(!$this->verify_data_is_ok($data['aud_id'],'intnum')){ return $this->msg(10005,'aud_id type error'); } if(!$this->verify_data_is_ok($data['one'],'intnum')){ return $this->msg(10005,'one type error'); } if(!$this->verify_data_is_ok($data['two'],'intnum')){ return $this->msg(10005,'two type error'); } if(!$this->verify_data_is_ok($data['three'],'intnum')){ return $this->msg(10005,'three type error'); } if(!$this->verify_data_is_ok($data['time'],'datetime')){ return $this->msg(10005,'time type error'); } if(strlen($data['time']) <= 12){ // 时间日期转换,把'Y-m-d'转换成'Y-m-d H:i:s'格式 $data['time'] = $this->addCurrentTimeToDateString($data['time']); } return $this->manual_record_action($data,'by_hand_means'); } catch (\Exception $e) { // 捕获异常 $logContent["flie"] = $e->getFile(); $logContent["line"] = $e->getLine(); $logContent['all_content'] = "异常信息:\n"; $logContent['all_content'] .= "消息: " . $e->getMessage() . "\n"; $logContent['all_content'] .= "代码: " . $e->getCode() . "\n"; $logContent['all_content'] .= "文件: " . $e->getFile() . "\n"; $logContent['all_content'] .= "行号: " . $e->getLine() . "\n"; $logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n"; $this->record_api_log($data, $logContent, null); return $this->msg(99999); } } // 设备记录 public function device_record(){ try { $data = input('post.'); if(!array_key_exists('aud_id', $data) || !array_key_exists('one', $data) || !array_key_exists('two', $data) || !array_key_exists('three', $data) || !array_key_exists('token', $data)){ return $this->msg(10001); } unset($data['token']); if(!$this->verify_data_is_ok($data['aud_id'],'intnum')){ return $this->msg(10005,'aud_id type error'); } if(!$this->verify_data_is_ok($data['one'],'intnum')){ return $this->msg(10005,'one type error'); } if(!$this->verify_data_is_ok($data['two'],'intnum')){ return $this->msg(10005,'two type error'); } if(!$this->verify_data_is_ok($data['three'],'intnum')){ return $this->msg(10005,'three type error'); } $data['time'] = date('Y-m-d H:i:s'); return $this->manual_record_action($data,'by_device'); } catch (\Exception $e) { // 捕获异常 $logContent["flie"] = $e->getFile(); $logContent["line"] = $e->getLine(); $logContent['all_content'] = "异常信息:\n"; $logContent['all_content'] .= "消息: " . $e->getMessage() . "\n"; $logContent['all_content'] .= "代码: " . $e->getCode() . "\n"; $logContent['all_content'] .= "文件: " . $e->getFile() . "\n"; $logContent['all_content'] .= "行号: " . $e->getLine() . "\n"; $logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n"; $this->record_api_log($data, $logContent, null); return $this->msg(99999); } } // 数据报告 public function data_report(){ try { $data = input('post.'); if(!array_key_exists('aud_id', $data) || !array_key_exists('token', $data)){ $return_data = $this->msg(10001); } unset($data['token']); if(!$this->verify_data_is_ok($data['aud_id'],'intnum')){ return $this->msg(10005,'aud_id type error'); } return $this->data_report_action($data); } catch (\Exception $e) { // 捕获异常 $logContent["flie"] = $e->getFile(); $logContent["line"] = $e->getLine(); $logContent['all_content'] = "异常信息:\n"; $logContent['all_content'] .= "消息: " . $e->getMessage() . "\n"; $logContent['all_content'] .= "代码: " . $e->getCode() . "\n"; $logContent['all_content'] .= "文件: " . $e->getFile() . "\n"; $logContent['all_content'] .= "行号: " . $e->getLine() . "\n"; $logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n"; $this->record_api_log($data, $logContent, null); return $this->msg(99999); } } // 曲线 public function curve_chart(){ try { // 你的业务逻辑 if(count(input('post.')) > 0){ $data = input('post.'); } if(!array_key_exists('aud_id', $data) || !array_key_exists('time', $data) || !array_key_exists('token', $data)){ $return_data = $this->msg(10001); } unset($data['token']); if(!$this->verify_data_is_ok($data['aud_id'],'intnum')){ return $this->msg(10005,'aud_id type error'); } if(!$this->verify_data_is_ok($data['time'],'datetime')){ return $this->msg(10005,'time type error'); } return $this->curve_chart_action($data); } catch (\Exception $e) { // 捕获异常 $logContent["flie"] = $e->getFile(); $logContent["line"] = $e->getLine(); $logContent['all_content'] = "异常信息:\n"; $logContent['all_content'] .= "消息: " . $e->getMessage() . "\n"; $logContent['all_content'] .= "代码: " . $e->getCode() . "\n"; $logContent['all_content'] .= "文件: " . $e->getFile() . "\n"; $logContent['all_content'] .= "行号: " . $e->getLine() . "\n"; $logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n"; $this->record_api_log($data, $logContent, null); return $this->msg(99999); } } // 获取历史列表(分页) public function record_list_page(){ try { $data = input('post.'); if(!array_key_exists('token', $data) || !array_key_exists('aud_id', $data) || !array_key_exists('page', $data)){ return $this->msg(10001); } if(!$this->verify_data_is_ok($data['token'],'str')){ return $this->msg(10005,'token type error'); } if(!$this->verify_data_is_ok($data['aud_id'],'intnum')){ return $this->msg(10005,'aud_id type error'); } if(!$this->verify_data_is_ok($data['page'],'intnum')){ return $this->msg(10005,'page type error'); } return $this->record_list_page_or_group_action($data,'page'); } catch (\Exception $e) { // 捕获异常 $logContent["flie"] = $e->getFile(); $logContent["line"] = $e->getLine(); $logContent['all_content'] = "异常信息:\n"; $logContent['all_content'] .= "消息: " . $e->getMessage() . "\n"; $logContent['all_content'] .= "代码: " . $e->getCode() . "\n"; $logContent['all_content'] .= "文件: " . $e->getFile() . "\n"; $logContent['all_content'] .= "行号: " . $e->getLine() . "\n"; $logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n"; $this->record_api_log($data, $logContent, null); return $this->msg(99999); } } // 获取历史列表(分组) public function record_list_group(){ try { $data = input('post.'); if(!array_key_exists('token', $data) || !array_key_exists('aud_id', $data) || !array_key_exists('s_time', $data) || !array_key_exists('e_time', $data)){ return $this->msg(10001); } if(!$this->verify_data_is_ok($data['token'],'str')){ return $this->msg(10005,'token type error'); } if(!$this->verify_data_is_ok($data['aud_id'],'intnum')){ return $this->msg(10005,'aud_id type error'); } if(!$this->verify_data_is_ok($data['s_time'],'datetime')){ return $this->msg(10005,'page type error'); } if(!$this->verify_data_is_ok($data['e_time'],'datetime')){ return $this->msg(10005,'page type error'); } return $this->record_list_page_or_group_action($data,'group'); } catch (\Exception $e) { // 捕获异常 $logContent["flie"] = $e->getFile(); $logContent["line"] = $e->getLine(); $logContent['all_content'] = "异常信息:\n"; $logContent['all_content'] .= "消息: " . $e->getMessage() . "\n"; $logContent['all_content'] .= "代码: " . $e->getCode() . "\n"; $logContent['all_content'] .= "文件: " . $e->getFile() . "\n"; $logContent['all_content'] .= "行号: " . $e->getLine() . "\n"; $logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n"; $this->record_api_log($data, $logContent, null); return $this->msg(99999); } } // 历史记录(详细) public function detailed_record(){ try { $data = input('post.'); if(!array_key_exists('token', $data) || !array_key_exists('id', $data)){ return $this->msg(10001); } if(!$this->verify_data_is_ok($data['token'],'str')){ return $this->msg(10005,'token type error'); } if(!$this->verify_data_is_ok($data['id'],'intnum')){ return $this->msg(10005,'id type error'); } return $this->get_all_detaile_data_action($data); } catch (\Exception $e) { // 捕获异常 $logContent["flie"] = $e->getFile(); $logContent["line"] = $e->getLine(); $logContent['all_content'] = "异常信息:\n"; $logContent['all_content'] .= "消息: " . $e->getMessage() . "\n"; $logContent['all_content'] .= "代码: " . $e->getCode() . "\n"; $logContent['all_content'] .= "文件: " . $e->getFile() . "\n"; $logContent['all_content'] .= "行号: " . $e->getLine() . "\n"; $logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n"; $this->record_api_log($data, $logContent, null); return $this->msg(99999); } } // 删除历史数据 public function del_record(){ try { $data = input('post.'); if(!array_key_exists('id', $data) || !array_key_exists('token', $data)){ return $this->msg(10001); } if(!$this->verify_data_is_ok($data['id'],'intnum')){ return $this->msg(10005); } unset($data['token']); $user_data = Db::table($this->vitalcapacity_db_name['vitalcapacity'])->where(['id'=>$data['id']])->update(['is_del'=>1]); if($user_data){ return $this->msg([]); }else{ return $this->msg(10002); } } catch (\Exception $e) { // 捕获异常 $logContent["flie"] = $e->getFile(); $logContent["line"] = $e->getLine(); $logContent['all_content'] = "异常信息:\n"; $logContent['all_content'] .= "消息: " . $e->getMessage() . "\n"; $logContent['all_content'] .= "代码: " . $e->getCode() . "\n"; $logContent['all_content'] .= "文件: " . $e->getFile() . "\n"; $logContent['all_content'] .= "行号: " . $e->getLine() . "\n"; $logContent['all_content'] .= "跟踪信息:\n" . $e->getTraceAsString() . "\n"; $this->record_api_log($data, $logContent, null); return $this->msg(99999); } } ################################################################action################################################################ ################################################################action################################################################ public function manual_record_action($data,$type){ $temporary_arr['aud_id'] = $data['aud_id']; $temporary_arr['record_time'] = $data['time']; $temporary_arr['one'] = $data['one']; $temporary_arr['two'] = $data['two']; $temporary_arr['three'] = $data['three']; $temporary_arr['average'] = bcdiv(bcadd(bcadd($data['one'],$data['two'],2),$data['three'],2),3,2); $temporary_arr['create_time'] = date('Y-m-d H:i:s'); $temporary_arr['one_val'] = $data['one']; $temporary_arr['two_val'] = $data['two']; $temporary_arr['three_val'] = $data['three']; $temporary_arr['average_val'] = $temporary_arr['average']; $temporary_arr['flow_val'] = array_key_exists('flow', $data)?$data['flow']:'0.00';//流速 $temporary_arr['record_type'] = $type;//流速 // die; // 处理记录时间 $user_msg = Db::name($this->vitalcapacity_db_name['juese'])->where(['id'=>$data['aud_id']])->field('id,grade,gender,birthday')->find(); // die; if($user_msg){ // 根据性别&年级&年龄查规则 if($user_msg['grade'] == 'nothing'){ // 计算年龄判断是属于哪个年级 $user_age = $this->calculate_age($user_msg['birthday']); if($user_age <= 7){ $user_msg['grade'] = 'grade_s_1'; }else if($user_age == 8){ $user_msg['grade'] = 'grade_s_2'; }else if($user_age == 9){ $user_msg['grade'] = 'grade_s_3'; }else if($user_age == 10){ $user_msg['grade'] = 'grade_s_4'; }else if($user_age == 11){ $user_msg['grade'] = 'grade_s_5'; }else if($user_age == 12){ $user_msg['grade'] = 'grade_s_6'; }else if($user_age == 13){ $user_msg['grade'] = 'grade_m_1'; }else if($user_age == 14){ $user_msg['grade'] = 'grade_m_2'; }else if($user_age == 15){ $user_msg['grade'] = 'grade_m_3'; }else if($user_age == 16){ $user_msg['grade'] = 'grade_h_1'; }else if($user_age == 17){ $user_msg['grade'] = 'grade_h_2'; }else if($user_age == 18){ $user_msg['grade'] = 'grade_h_3'; }else if($user_age == 19 || $user_age == 20){ $user_msg['grade'] = 'grade_u_12'; }else if($user_age >= 21){ $user_msg['grade'] = 'grade_u_34'; } } $sql_str = "sex = ".$user_msg['gender']." and ".$user_msg['grade']." <= ".$temporary_arr['average_val']; $user_achievement = Db::name($this->vitalcapacity_db_name['biaozhun'])->where($sql_str)->order($user_msg['grade'] .' desc')->field('level,score,'.$user_msg['grade'])->limit(1)->cache(86400)->select(); if(count($user_achievement)<=0){ $user_achievement[0] = ['level'=>'无效','score'=>'0']; } $temporary_arr['score'] = $user_achievement[0]['score'].','.$user_achievement[0]['level'].','.$this->color[$user_achievement[0]['level']]; $temporary_arr['score_val'] = $user_achievement[0]['score']; }else{ return $this->msg(10004,'未找到有效数据'); } $standard_data = $this->get_vitalcapacity_data($data['aud_id']); $temporary_arr['standard_data'] = json_encode($standard_data); $result = Db::table($this->vitalcapacity_db_name['vitalcapacity'])->insert($temporary_arr); if($result){ $time = $result[0]['record_time']; $time = strtotime($time); $time = date('Y年m月d日 H:i:s', $time); return $this->msg([ 'average'=>$temporary_arr['average'].'ml', 'level'=>$user_achievement[0]['level'], 'time'=>$time, 'flow_val'=>$temporary_arr['flow_val'], 'list'=>$standard_data, 'offset'=>$this->vitalcapacity_standard_interval($temporary_arr['average'],$standard_data) ]); }else{ return $this->msg(10002); } } public function data_report_action($data){ $result = Db::table($this->vitalcapacity_db_name['vitalcapacity'])->where(['aud_id'=>$data['aud_id']])->order('record_time desc')->field('record_time,score,average,flow_val,standard_data')->limit(1)->select(); if(count($result) <= 0){ // return $this->msg(10004); return $this->msg([ 'average'=>'', 'level'=>'', 'time'=>'', 'flow_val'=>'', 'list'=>'', 'offset'=>'' ]); }else{ $time = $result[0]['record_time']; $time = strtotime($time); $time = date('Y年m月d日 H:i:s', $time); $o_l = explode(',',$result[0]['score']); // $standard_data = $this->get_vitalcapacity_data($data['aud_id']); $standard_data = json_decode($result[0]['standard_data'],true); return $this->msg([ 'average'=>$result[0]['average'].'ml', 'level'=>$o_l[1], 'time'=>$time, 'flow_val'=>$result[0]['flow_val'] == '.00'?'0.00':$result[0]['flow_val'], 'list'=>$standard_data, 'offset'=>$this->vitalcapacity_standard_interval($result[0]['average'],$standard_data) ]); } } public function curve_chart_action($data){ $audid = $data['aud_id']; $timeData = explode('-', $data['time']); // 根据$timeData的长度构建不同的查询条件 $map = ['aud_id' => $audid]; switch (count($timeData)) { case 3: // 年月日 $map['record_time'] = ['between', [date('Y-m-d 00:00:00', strtotime($timeData[0] . '-' . $timeData[1] . '-' . $timeData[2])), date('Y-m-d 23:59:59', strtotime($timeData[0] . '-' . $timeData[1] . '-' . $timeData[2]))]]; break; case 2: // 年月 $map['record_time'] = ['between', [date('Y-m-01 00:00:00', strtotime($timeData[0] . '-' . $timeData[1])), date('Y-m-t 23:59:59', strtotime($timeData[0] . '-' . $timeData[1]))]]; break; case 1: // 年 $map['record_time'] = ['between', [date('Y-01-01 00:00:00', strtotime($timeData[0])), date('Y-12-31 23:59:59', strtotime($timeData[0]))]]; break; default: return $this->msg(10005); // 无效的时间数据格式 } // 使用查询构造器进行查询 $result = Db::name($this->vitalcapacity_db_name['vitalcapacity'])->where($map)->field('id,one_val,two_val,three_val,average_val,score_val,aud_id,record_time,DATEPART(hour, record_time) AS hour,DATEPART(day, record_time) AS day,DATEPART(month, record_time) AS month')->order('record_time')->select(); $return_data = []; if(count($timeData) == 3){ $key_condition = 'hour'; }else if(count($timeData) == 2){ $key_condition = 'day'; }else if(count($timeData) == 1){ $key_condition = 'month'; } foreach ($this->curve_data_format as $key => $value) { $temporary_arr['title'] = $value[0].'('.$value[1].')'; $temporary_arr['key'] = $key; $temporary_arr['line']['categories'] = []; $temporary_arr['line']['series'][0]['color'] = $value[2]; $temporary_arr['line']['series'][0]['name'] = $value[0].'('.$value[1].')'; $temporary_arr['line']['series'][0]['data'] = []; foreach ($result as $k => $v) { if($key_condition == 'hour'){ if(in_array($result[$k][$key_condition].'时',$temporary_arr['line']['categories'])){ $num = array_search($result[$k][$key_condition].'时', $temporary_arr['line']['categories']); // $temporary_arr['line']['series'][0]['data'][$num] = bcadd($temporary_arr['line']['series'][0]['data'][$num],$result[$k][$key],2); $temporary_arr['line']['series'][0]['data'][$num] = $temporary_arr['line']['series'][0]['data'][$num] >= $result[$k][$key]?$temporary_arr['line']['series'][0]['data'][$num]:$result[$k][$key]; }else{ array_push($temporary_arr['line']['categories'],$result[$k][$key_condition].'时'); array_push($temporary_arr['line']['series'][0]['data'],$result[$k][$key]); } }else if($key_condition == 'day'){ if(in_array($result[$k]['month'].'-'.$result[$k][$key_condition],$temporary_arr['line']['categories'])){ $num = array_search($result[$k]['month'].'-'.$result[$k][$key_condition], $temporary_arr['line']['categories']); // $temporary_arr['line']['series'][0]['data'][$num] = bcadd($temporary_arr['line']['series'][0]['data'][$num],$result[$k][$key],2); $temporary_arr['line']['series'][0]['data'][$num] = $temporary_arr['line']['series'][0]['data'][$num] >= $result[$k][$key]?$temporary_arr['line']['series'][0]['data'][$num]:$result[$k][$key]; }else{ array_push($temporary_arr['line']['categories'],$result[$k]['month'].'-'.$result[$k][$key_condition]); array_push($temporary_arr['line']['series'][0]['data'],$result[$k][$key]); } }else{ if(in_array($result[$k]['month'].'月',$temporary_arr['line']['categories'])){ $num = array_search($result[$k]['month'].'月', $temporary_arr['line']['categories']); // $temporary_arr['line']['series'][0]['data'][$num] = bcadd($temporary_arr['line']['series'][0]['data'][$num],$result[$k][$key],2); $temporary_arr['line']['series'][0]['data'][$num] = $temporary_arr['line']['series'][0]['data'][$num] >= $result[$k][$key]?$temporary_arr['line']['series'][0]['data'][$num]:$result[$k][$key]; }else{ array_push($temporary_arr['line']['categories'],$result[$k]['month'].'月'); array_push($temporary_arr['line']['series'][0]['data'],$result[$k][$key]); } } } array_push($return_data,$temporary_arr); } return $this->msg($return_data); } public function record_list_page_or_group_action($data,$type){ $return_result = []; if($type == 'group'){ $data['s_time'] = $data['s_time'].' 00:00:00'; $data['e_time'] = $data['e_time'].' 23:59:59'; $result = Db::query(" select id, CONVERT(varchar(10), record_time, 120) AS r_t, CONVERT(varchar(19), record_time, 120) AS record_time, one_val as v1, two_val as v2, three_val as v3, average_val as v4, score as v5 from ".$this->vitalcapacity_db_name['vitalcapacity']." where aud_id='".$data['aud_id']."' and record_time between '".$data['s_time']."' and '".$data['e_time']."' and is_del = 0 order by record_time desc"); foreach ($result as $key => $value) { // $time_t = $this->handle_hour_branch_second($value['v2']); array_push($return_result, [ 'id'=>$value['id'], 'v1'=>$value['v1'] == '.00'?'0':$value['v1'], 'v2'=>$value['v2'] == '.00'?'0':$value['v2'], 'v3'=>$value['v3'] == '.00'?'0':$value['v3'], 'v4'=>$value['v4'] == '.00'?'0':$value['v4'], 'v5'=>explode(',',$value['v5'])[0], 'v1_name'=>'第一次', 'v2_name'=>'第二次', 'v3_name'=>'第三次', 'v4_name'=>'平均', 'v5_name'=>'成绩', // 'r_t'=>str_replace('-', '/', $value['r_t']) 'r_t'=>$value['r_t'] ]); } }else{ $result = Db::table($this->vitalcapacity_db_name['vitalcapacity'])->where(['aud_id'=>$data['aud_id'],'is_del'=>0])->field("id,record_time,REPLACE(record_time, '-', '-') AS b_time,one_val,two_val,three_val,average_val,score")->order('record_time desc')->page($data['page'],$this->pagesize)->select(); $return_result['totalrows'] = Db::table($this->vitalcapacity_db_name['vitalcapacity'])->where(['aud_id'=>$data['aud_id']])->count(); $return_result['rows'] = []; $return_result['pageno'] = $data['page']; $return_result['pagesize'] = $this->pagesize; $return_result['totalpage'] = ceil($return_result['totalrows']/$this->pagesize); foreach ($result as $key => $value) { // $time_t = $this->handle_hour_branch_second($value['jump_time']); array_push($return_result['rows'],[ 'id'=>$value['id'], 'v1'=>$value['one_val'] == '.00'?'0':$value['one_val'], 'v2'=>$value['two_val'] == '.00'?'0':$value['two_val'], 'v3'=>$value['three_val'] == '.00'?'0':$value['three_val'], 'v4'=>$value['average_val'] == '.00'?'0':$value['average_val'], 'v5'=>explode(',',$value['score'])[0], 'v1_name'=>'第一次', 'v2_name'=>'第二次', 'v3_name'=>'第三次', 'v4_name'=>'平均', 'v5_name'=>'成绩', 'record_time'=>$value['b_time'] ]); } } return $this->msg($return_result); } public function get_all_detaile_data_action($data){ $result = $result = Db::table($this->vitalcapacity_db_name['vitalcapacity'])->where(['id'=>$data['id'],'is_del'=>0])->find(); $for_data_arr = ['one_val'=>['第一次','ml'],'two_val'=>['第二次','ml'],'three_val'=>['第三次','ml'],'average_val'=>['三次平均','ml'],'score'=>['最后成绩','分']]; if($result){ $result_data = []; foreach ($for_data_arr as $key => $value) { $temporary_arr['key_name'] = $key; $temporary_arr['name'] = $value[0]; $temporary_arr['value'] = explode(',',$result[$key])[0]; $temporary_arr['unit'] = $value[1]; array_push($result_data,$temporary_arr); } return $this->msg($result_data); }else{ return $this->msg(10002); } } ################################################################内部调用################################################################ ################################################################内部调用################################################################ // 肺活量判断区间 public function vitalcapacity_standard_interval($val,$data){ // 缓存一周 $result = ''; if(!$data || count($data) <= 0){ return $result; } $temporary_qj = $data; $max = 0; $min = 0; $num = 0; foreach ($temporary_qj as $key => $value) { if($val >= $value['min_val'] && $val <= $value['max_val']){ $max = $value['max_val']; $min = $value['min_val']; $num = $key; break; } } $num = count($temporary_qj)-1-$num; if($max == 0){ if($val >= $temporary_qj[0]['max_val']){ $result = 100; } }else{ $temporary_num = bcmul(bcdiv(bcsub($val,$min,20),bcsub($max,$min,20),2),bcdiv(100,count($temporary_qj),2),2); $result = bcadd(bcmul(bcdiv(100,count($temporary_qj),2),$num,2),$temporary_num,2); } return $result; } // 肺活量判断区间(根据得分) public function vitalcapacity_standard_interval2($val,$data){ // 缓存一周 $result = ''; if(count($data) <= 0){ return $result; } $temporary_qj = $data; $max = 0; $min = 0; $num = 0; foreach ($temporary_qj as $key => $value) { if($val >= $value['min_val'] && $val <= $value['max_val']){ $max = $value['max_val']; $min = $value['min_val']; $num = $key; break; } } // 计算每份占比 $share_value = bcdiv($temporary_qj[0]['max_val'],count($temporary_qj),1); // 计算在这一段中占多少 $result = bcsub($val,$min,1); $result = bcdiv($result,bcsub($max,$min,1),1); $num = count($temporary_qj)-1-$num; $num = bcmul($num,$share_value,1); $result = bcadd($num,$result,1); // $num = count($temporary_qj)-1-$num; // $temporary_num = bcmul(bcdiv(bcsub($val,$min,20),bcsub($max,$min,20),2),bcdiv(100,count($temporary_qj),2),2); // $result = bcadd(bcmul(bcdiv(100,count($temporary_qj),2),$num,2),$temporary_num,2); return $result; } }