|
@@ -161,16 +161,25 @@ class Exercise extends Backend
|
|
|
$fault_two_score = 25;
|
|
|
$fault_three_score = 25;
|
|
|
|
|
|
+ //故障现象
|
|
|
$xianxian_score = 0;
|
|
|
- $yuanyin_socre= 0;
|
|
|
+ $xianxian_arr = [];
|
|
|
+ $xianxian_content = [];
|
|
|
+
|
|
|
+ //故障部位
|
|
|
$buwei_score= 0;
|
|
|
- $fangfa_score= 0;
|
|
|
+ $buwei_arr = [];
|
|
|
+ $buwei_content = [];
|
|
|
|
|
|
- $xianxian_arr = [];
|
|
|
+ //可能原因
|
|
|
+ $yuanyin_socre= 0;
|
|
|
$yuanyin_arr = [];
|
|
|
- $buwei_arr = [];
|
|
|
+ $yuanyin_content = [];
|
|
|
+
|
|
|
+ //排除方法
|
|
|
+ $fangfa_score= 0;
|
|
|
$fangfa_arr = [];
|
|
|
- $jielun_score = 0;
|
|
|
+ $fangfa_content = [];
|
|
|
|
|
|
|
|
|
Db::startTrans();
|
|
@@ -241,127 +250,261 @@ class Exercise extends Backend
|
|
|
foreach ($other_report as $key => $em){
|
|
|
//故障现象
|
|
|
$xianxian_arr[] = $em['xx_id'];
|
|
|
- //故障部位
|
|
|
- $buwei_arr[] = $em['bw_id'];
|
|
|
- //可能原因
|
|
|
- foreach(explode(',',$em['yy_id']) as $k3 =>$t13){
|
|
|
- $yuanyin_arr[] = $t13;
|
|
|
- }
|
|
|
- //排除方法
|
|
|
- $fangfa_arr[] = $em['pc_id'];
|
|
|
}
|
|
|
- }
|
|
|
-
|
|
|
- //故障现象 分数 start
|
|
|
- foreach ($partent_fault_id as $k1 =>$t){
|
|
|
- if(!in_array($t,$xianxian_arr)){
|
|
|
- $xianxian_score = 1+$xianxian_score;
|
|
|
- $xianxian_content[] = [
|
|
|
- 'cx_id'=>$t,
|
|
|
- 'cx_type'=>'少写',
|
|
|
- 'cx_name'=>Fault::where(['fault_id'=>$t])->value('name'),
|
|
|
- ];
|
|
|
+ foreach ($partent_fault_id as $k1 =>$t){
|
|
|
+ if(!in_array($t,$xianxian_arr)){
|
|
|
+ $xianxian_score = 5+$xianxian_score;
|
|
|
+ $xianxian_content[] = [
|
|
|
+ 'gzxz_id'=>$t,
|
|
|
+ 'cx_id'=>$t,
|
|
|
+ 'cx_type'=>'故障现象少写',
|
|
|
+ 'cx_name'=>Fault::where(['fault_id'=>$t])->value('name'),
|
|
|
+ ];
|
|
|
+ }else{
|
|
|
+ // echo "存在里面".$t."###".$k1."<br/>";
|
|
|
+ $jian = '';
|
|
|
+ foreach ($other_report as $ky => $item) {
|
|
|
+ if ($item['xx_id'] == $t) {
|
|
|
+ $jian = $ky;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ // echo $jian."<br/>";
|
|
|
+
|
|
|
+ // 故障部位算分 start
|
|
|
+ //获取故障部位
|
|
|
+ $buweiarr = Fault::where(['parent_fault_id'=>$t,'sim_type'=>$info['sim_type'],'fault_type'=>['in',[3,30]],'fault_state'=>0])
|
|
|
+ ->column('fault_id');
|
|
|
+ if(!in_array($other_report[$jian]['bw_id'],$buweiarr)){
|
|
|
+ $buwei_score = 1+$buwei_score;
|
|
|
+ $xianxian_content[] = [
|
|
|
+ 'gzxz_id'=>$t,
|
|
|
+ 'cx_id'=>$other_report[$jian]['bw_id'],
|
|
|
+ 'cx_type'=>'故障部位错写',
|
|
|
+ 'cx_name'=>Fault::where(['fault_id'=>$other_report[$jian]['bw_id']])->value('name'),
|
|
|
+ ];
|
|
|
+ }
|
|
|
+ //出题故障部位和获取的故障部位里面有重复的
|
|
|
+ // 获取两个数组的交集
|
|
|
+ $intersection = array_intersect($buweiarr, $fault_arr);
|
|
|
+ // halt($intersection);
|
|
|
+ foreach($intersection as $kk =>$va){
|
|
|
+ if($other_report[$jian]['bw_id']!=$va){
|
|
|
+ $buwei_score = 1+$buwei_score;
|
|
|
+ $xianxian_content[] = [
|
|
|
+ 'gzxz_id'=>$t,
|
|
|
+ 'cx_id'=>$va,
|
|
|
+ 'cx_type'=>'故障部位少写',
|
|
|
+ 'cx_name'=>Fault::where(['fault_id'=>$va])->value('name'),
|
|
|
+ ];
|
|
|
+ }
|
|
|
+ }
|
|
|
+ unset($va);
|
|
|
+ // 故障部位算分 end
|
|
|
+
|
|
|
+ // 排除方法算分 start
|
|
|
+ $paichuarr = Fault::where(['parent_fault_id'=>$t,'sim_type'=>$info['sim_type'],'fault_type'=>4,'fault_state'=>0])
|
|
|
+ ->column('fault_id');
|
|
|
+ if(!in_array($other_report[$jian]['pc_id'],$paichuarr)){
|
|
|
+ $fangfa_score = 1+$fangfa_score;
|
|
|
+ $xianxian_content[] = [
|
|
|
+ 'gzxz_id'=>$t,
|
|
|
+ 'cx_id'=>$other_report[$jian]['pc_id'],
|
|
|
+ 'cx_type'=>'排除方法错写',
|
|
|
+ 'cx_name'=>Fault::where(['fault_id'=>$other_report[$jian]['pc_id']])->value('name'),
|
|
|
+ ];
|
|
|
+ }
|
|
|
+ //出题排除方法和获取的排除方法里面有重复的
|
|
|
+ // 获取两个数组的交集
|
|
|
+ $intersection1 = array_intersect($paichuarr, $paichu_arr);
|
|
|
+ foreach($intersection1 as $kk1 =>$va1){
|
|
|
+ if($other_report[$jian]['pc_id']!=$va1){
|
|
|
+ $fangfa_score = 1+$fangfa_score;
|
|
|
+ $xianxian_content[] = [
|
|
|
+ 'gzxz_id'=>$t,
|
|
|
+ 'cx_id'=>$va1,
|
|
|
+ 'cx_type'=>'排除方法少写',
|
|
|
+ 'cx_name'=>Fault::where(['fault_id'=>$va1])->value('name'),
|
|
|
+ ];
|
|
|
+ }
|
|
|
+ }
|
|
|
+ unset($va1);
|
|
|
+ // 排除方法算分 end
|
|
|
+
|
|
|
+ // 可能原因算分 start
|
|
|
+ $yuanyinarr = Fault::where(['parent_fault_id'=>$t,'sim_type'=>$info['sim_type'],'fault_type'=>2,'fault_state'=>0])
|
|
|
+ ->column('fault_id');
|
|
|
+ foreach (explode(',',$other_report[$jian]['yy_id']) as $key => $value) {
|
|
|
+ if(!in_array($value,$yuanyinarr)){
|
|
|
+ $yuanyin_socre = 1+$yuanyin_socre;
|
|
|
+ $xianxian_content[] = [
|
|
|
+ 'gzxz_id'=>$t,
|
|
|
+ 'cx_id'=>$value,
|
|
|
+ 'cx_type'=>'可能原因错写',
|
|
|
+ 'cx_name'=>Fault::where(['fault_id'=>$value])->value('name'),
|
|
|
+ ];
|
|
|
+ }
|
|
|
+ }
|
|
|
+ //出题可能原因和获取的可能原因里面有重复的
|
|
|
+ // 获取两个数组的交集
|
|
|
+ $intersection2 = array_intersect($yy_arr, $yuanyinarr);
|
|
|
+ $intersection22 = array_intersect($intersection2, explode(',',$other_report[$jian]['yy_id']));
|
|
|
+ foreach($yuanyinarr as $kk2 =>$va2){
|
|
|
+ if(!in_array($va2,$intersection22)){
|
|
|
+ $yuanyin_socre = 1+$yuanyin_socre;
|
|
|
+ $xianxian_content[] = [
|
|
|
+ 'gzxz_id'=>$t,
|
|
|
+ 'cx_id'=>$va2,
|
|
|
+ 'cx_type'=>'可能原因少写',
|
|
|
+ 'cx_name'=>Fault::where(['fault_id'=>$va2])->value('name'),
|
|
|
+ ];
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+ unset($va2);
|
|
|
+ // 可能原因算分 end
|
|
|
+ }
|
|
|
}
|
|
|
- }
|
|
|
- foreach ($xianxian_arr as $k2 =>$t2){
|
|
|
- if(!in_array($t2,$partent_fault_id)){
|
|
|
- $xianxian_score = 1+$xianxian_score;
|
|
|
+ unset($em);
|
|
|
+ }else{
|
|
|
+ foreach ($partent_fault_id as $key => $em){
|
|
|
+ $xianxian_score = 5+$xianxian_score;
|
|
|
$xianxian_content[] = [
|
|
|
- 'cx_id'=>$t2,
|
|
|
- 'cx_type'=>'错写',
|
|
|
- 'cx_name'=>Fault::where(['fault_id'=>$t2])->value('name'),
|
|
|
+ 'gzxz_id'=>$em,
|
|
|
+ 'cx_id'=>$em,
|
|
|
+ 'cx_type'=>'故障现象少写',
|
|
|
+ 'cx_name'=>Fault::where(['fault_id'=>$em])->value('name'),
|
|
|
];
|
|
|
}
|
|
|
+ unset($em);
|
|
|
}
|
|
|
- //故障现象 end
|
|
|
+
|
|
|
+ // //获取数组
|
|
|
+ // $other_report = json_decode($params['other_report'],true);
|
|
|
+ // if(!empty($other_report)){
|
|
|
+ // foreach ($other_report as $key => $em){
|
|
|
+ // //故障现象
|
|
|
+ // $xianxian_arr[] = $em['xx_id'];
|
|
|
+ // //故障部位
|
|
|
+ // $buwei_arr[] = $em['bw_id'];
|
|
|
+ // //可能原因
|
|
|
+ // foreach(explode(',',$em['yy_id']) as $k3 =>$t13){
|
|
|
+ // $yuanyin_arr[] = $t13;
|
|
|
+ // }
|
|
|
+ // //排除方法
|
|
|
+ // $fangfa_arr[] = $em['pc_id'];
|
|
|
+ // }
|
|
|
+ // }
|
|
|
+
|
|
|
+ // //故障现象 分数 start
|
|
|
+ // foreach ($partent_fault_id as $k1 =>$t){
|
|
|
+ // if(!in_array($t,$xianxian_arr)){
|
|
|
+ // $xianxian_score = 1+$xianxian_score;
|
|
|
+ // $xianxian_content[] = [
|
|
|
+ // 'cx_id'=>$t,
|
|
|
+ // 'cx_type'=>'少写',
|
|
|
+ // 'cx_name'=>Fault::where(['fault_id'=>$t])->value('name'),
|
|
|
+ // ];
|
|
|
+ // }
|
|
|
+ // }
|
|
|
+ // foreach ($xianxian_arr as $k2 =>$t2){
|
|
|
+ // if(!in_array($t2,$partent_fault_id)){
|
|
|
+ // $xianxian_score = 1+$xianxian_score;
|
|
|
+ // $xianxian_content[] = [
|
|
|
+ // 'cx_id'=>$t2,
|
|
|
+ // 'cx_type'=>'错写',
|
|
|
+ // 'cx_name'=>Fault::where(['fault_id'=>$t2])->value('name'),
|
|
|
+ // ];
|
|
|
+ // }
|
|
|
+ // }
|
|
|
+ // //故障现象 end
|
|
|
|
|
|
|
|
|
- //故障部位 start
|
|
|
- foreach ($fault_arr as $k11 =>$t11){
|
|
|
- if(!in_array($t11,$buwei_arr)){
|
|
|
- $buwei_score = 1+$buwei_score;
|
|
|
- $buwei_content[] = [
|
|
|
- 'cx_id'=>$t11,
|
|
|
- 'cx_type'=>'少写',
|
|
|
- 'cx_name'=>Fault::where(['fault_id'=>$t11])->value('name'),
|
|
|
- ];
|
|
|
- }
|
|
|
- }
|
|
|
- foreach ($buwei_arr as $k12 =>$t12){
|
|
|
- if(!empty($t12) && !in_array($t12,$fault_arr)){
|
|
|
- //错写
|
|
|
- $buwei_score = 1+$buwei_score;
|
|
|
- $buwei_content[] = [
|
|
|
- 'cx_id'=>$t12,
|
|
|
- 'cx_type'=>'错写',
|
|
|
- 'cx_name'=>Fault::where(['fault_id'=>$t12])->value('name'),
|
|
|
- ];
|
|
|
- }
|
|
|
- }
|
|
|
- //故障部位 end
|
|
|
+ // //故障部位 start
|
|
|
+ // foreach ($fault_arr as $k11 =>$t11){
|
|
|
+ // if(!in_array($t11,$buwei_arr)){
|
|
|
+ // $buwei_score = 1+$buwei_score;
|
|
|
+ // $buwei_content[] = [
|
|
|
+ // 'cx_id'=>$t11,
|
|
|
+ // 'cx_type'=>'少写',
|
|
|
+ // 'cx_name'=>Fault::where(['fault_id'=>$t11])->value('name'),
|
|
|
+ // ];
|
|
|
+ // }
|
|
|
+ // }
|
|
|
+ // foreach ($buwei_arr as $k12 =>$t12){
|
|
|
+ // if(!empty($t12) && !in_array($t12,$fault_arr)){
|
|
|
+ // //错写
|
|
|
+ // $buwei_score = 1+$buwei_score;
|
|
|
+ // $buwei_content[] = [
|
|
|
+ // 'cx_id'=>$t12,
|
|
|
+ // 'cx_type'=>'错写',
|
|
|
+ // 'cx_name'=>Fault::where(['fault_id'=>$t12])->value('name'),
|
|
|
+ // ];
|
|
|
+ // }
|
|
|
+ // }
|
|
|
+ // //故障部位 end
|
|
|
|
|
|
- //排除方法 start
|
|
|
- //循环固定的排除方法,匹配作答的排除方法
|
|
|
- foreach ($paichu_arr as $k21 =>$t21){
|
|
|
- if(!in_array($t21,$fangfa_arr)){
|
|
|
- $fangfa_score = 1+$fangfa_score;
|
|
|
- $fangfa_content[] = [
|
|
|
- 'cx_id'=>$t21,
|
|
|
- 'cx_type'=>'少写',
|
|
|
- 'cx_name'=>Fault::where(['fault_id'=>$t21])->value('name'),
|
|
|
- ];
|
|
|
- }
|
|
|
- }
|
|
|
- //循环作答的排除方法,,匹配固定的排除方法
|
|
|
- foreach ($fangfa_arr as $k22 =>$t22){
|
|
|
- if(!empty($t22) && !in_array($t22,$paichu_arr)){
|
|
|
- $fangfa_score = 1+$fangfa_score;
|
|
|
- $fangfa_content[] = [
|
|
|
- 'cx_id'=>$t22,
|
|
|
- 'cx_type'=>'错写',
|
|
|
- 'cx_name'=>Fault::where(['fault_id'=>$t22])->value('name'),
|
|
|
- ];
|
|
|
- }
|
|
|
- }
|
|
|
- //排除方法 end
|
|
|
-
|
|
|
- //可能原因 start
|
|
|
- //循环固定的可能原因,匹配作答的可能原因
|
|
|
- foreach ($yy_arr as $k31 =>$t31){
|
|
|
- if(!in_array($t31,$yuanyin_arr)){
|
|
|
- // echo $t31."<br/>";
|
|
|
- $yuanyin_socre = 1+$yuanyin_socre;
|
|
|
- $yuanyin_content[] = [
|
|
|
- 'cx_id'=>$t31,
|
|
|
- 'cx_type'=>'少写',
|
|
|
- 'cx_name'=>Fault::where(['fault_id'=>$t31])->value('name'),
|
|
|
- ];
|
|
|
- }
|
|
|
- }
|
|
|
- //循环作答的排除方法,,匹配固定的排除方法
|
|
|
- foreach ($yuanyin_arr as $k32 =>$t32){
|
|
|
- if(!empty($t32) && !in_array($t32,$yy_arr)){
|
|
|
- $yuanyin_socre = 1+$yuanyin_socre;
|
|
|
- $yuanyin_content[] = [
|
|
|
- 'cx_id'=>$t32,
|
|
|
- 'cx_type'=>'错写',
|
|
|
- 'cx_name'=>Fault::where(['fault_id'=>$t32])->value('name'),
|
|
|
- ];
|
|
|
- }
|
|
|
- }
|
|
|
- $uniqueArray = array_unique($yuanyin_arr);
|
|
|
- $diff = array_diff_assoc($yuanyin_arr, $uniqueArray);
|
|
|
- if(!empty($diff)){
|
|
|
- foreach ($diff as $k323 =>$t323){
|
|
|
- $yuanyin_socre = 1+$yuanyin_socre;
|
|
|
- $yuanyin_content[] = [
|
|
|
- 'cx_id'=>$t323,
|
|
|
- 'cx_type'=>'错写',
|
|
|
- 'cx_name'=>Fault::where(['fault_id'=>$t323])->value('name'),
|
|
|
- ];
|
|
|
- }
|
|
|
- }
|
|
|
- //可能原因 end
|
|
|
+ // //排除方法 start
|
|
|
+ // //循环固定的排除方法,匹配作答的排除方法
|
|
|
+ // foreach ($paichu_arr as $k21 =>$t21){
|
|
|
+ // if(!in_array($t21,$fangfa_arr)){
|
|
|
+ // $fangfa_score = 1+$fangfa_score;
|
|
|
+ // $fangfa_content[] = [
|
|
|
+ // 'cx_id'=>$t21,
|
|
|
+ // 'cx_type'=>'少写',
|
|
|
+ // 'cx_name'=>Fault::where(['fault_id'=>$t21])->value('name'),
|
|
|
+ // ];
|
|
|
+ // }
|
|
|
+ // }
|
|
|
+ // //循环作答的排除方法,,匹配固定的排除方法
|
|
|
+ // foreach ($fangfa_arr as $k22 =>$t22){
|
|
|
+ // if(!empty($t22) && !in_array($t22,$paichu_arr)){
|
|
|
+ // $fangfa_score = 1+$fangfa_score;
|
|
|
+ // $fangfa_content[] = [
|
|
|
+ // 'cx_id'=>$t22,
|
|
|
+ // 'cx_type'=>'错写',
|
|
|
+ // 'cx_name'=>Fault::where(['fault_id'=>$t22])->value('name'),
|
|
|
+ // ];
|
|
|
+ // }
|
|
|
+ // }
|
|
|
+ // //排除方法 end
|
|
|
+
|
|
|
+ // //可能原因 start
|
|
|
+ // //循环固定的可能原因,匹配作答的可能原因
|
|
|
+ // foreach ($yy_arr as $k31 =>$t31){
|
|
|
+ // if(!in_array($t31,$yuanyin_arr)){
|
|
|
+ // // echo $t31."<br/>";
|
|
|
+ // $yuanyin_socre = 1+$yuanyin_socre;
|
|
|
+ // $yuanyin_content[] = [
|
|
|
+ // 'cx_id'=>$t31,
|
|
|
+ // 'cx_type'=>'少写',
|
|
|
+ // 'cx_name'=>Fault::where(['fault_id'=>$t31])->value('name'),
|
|
|
+ // ];
|
|
|
+ // }
|
|
|
+ // }
|
|
|
+ // //循环作答的排除方法,,匹配固定的排除方法
|
|
|
+ // foreach ($yuanyin_arr as $k32 =>$t32){
|
|
|
+ // if(!empty($t32) && !in_array($t32,$yy_arr)){
|
|
|
+ // $yuanyin_socre = 1+$yuanyin_socre;
|
|
|
+ // $yuanyin_content[] = [
|
|
|
+ // 'cx_id'=>$t32,
|
|
|
+ // 'cx_type'=>'错写',
|
|
|
+ // 'cx_name'=>Fault::where(['fault_id'=>$t32])->value('name'),
|
|
|
+ // ];
|
|
|
+ // }
|
|
|
+ // }
|
|
|
+ // $uniqueArray = array_unique($yuanyin_arr);
|
|
|
+ // $diff = array_diff_assoc($yuanyin_arr, $uniqueArray);
|
|
|
+ // if(!empty($diff)){
|
|
|
+ // foreach ($diff as $k323 =>$t323){
|
|
|
+ // $yuanyin_socre = 1+$yuanyin_socre;
|
|
|
+ // $yuanyin_content[] = [
|
|
|
+ // 'cx_id'=>$t323,
|
|
|
+ // 'cx_type'=>'错写',
|
|
|
+ // 'cx_name'=>Fault::where(['fault_id'=>$t323])->value('name'),
|
|
|
+ // ];
|
|
|
+ // }
|
|
|
+ // }
|
|
|
+ // //可能原因 end
|
|
|
|
|
|
|
|
|
$weixiu_score = $xianxian_score+$yuanyin_socre+$buwei_score+$fangfa_score;
|
|
@@ -499,7 +642,22 @@ class Exercise extends Backend
|
|
|
}
|
|
|
|
|
|
$other_report = !empty($row['other_report']) ? json_decode($row['other_report'],true):[];
|
|
|
+ $fault_right_list = Db::name('real_exam_fault')->where(['exam_id'=>$ids,'flag'=>1])->select();
|
|
|
+ //根据故障部位 数组
|
|
|
+ $fault_arr = [$fault_right_list[0]['fault_id'],$fault_right_list[1]['fault_id'],$fault_right_list[2]['fault_id']];
|
|
|
+
|
|
|
+ //查找故障现象 数组
|
|
|
+ $partent_fault_id = Fault::where(['fault_id'=>['in',$fault_arr],'sim_type'=>$rows['sim_type']])->column('parent_fault_id');
|
|
|
+ $arr1= [];
|
|
|
+ foreach ($partent_fault_id as $key => $value) {
|
|
|
+ $arr1[] = [
|
|
|
+ 'gzxz_id' => $value,
|
|
|
+ 'xianxian_content' => $row['xianxian_content_name'],
|
|
|
+ 'other_report' => $other_report
|
|
|
+ ];
|
|
|
+ }
|
|
|
$this->view->assign('other_report', $other_report);
|
|
|
+ $this->view->assign('partent_fault_id', $arr1);
|
|
|
$this->view->assign('row', $row);
|
|
|
return $this->view->fetch();
|
|
|
}
|