Tongji.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. <?php
  2. namespace app\admin\controller;
  3. use app\admin\model\Admin;
  4. use app\admin\model\User;
  5. use app\common\controller\Backend;
  6. use app\common\model\Attachment;
  7. use fast\Date;
  8. use think\Db;
  9. /**
  10. * 统计
  11. *
  12. * @icon fa fa-dashboard
  13. * @remark 用于展示当前系统中的统计数据、统计报表及重要实时数据
  14. */
  15. class Tongji extends Backend
  16. {
  17. /**
  18. * 报表统计
  19. */
  20. public function tongji(){
  21. $starttime = strtotime(date('Y-m-d',strtotime("-7 day"))); //默认7天前
  22. $endtime = strtotime(date('Y-m-d')) - 1;
  23. //接收
  24. $choicedatetime = input('choicedatetime','');
  25. if(!empty($choicedatetime)){
  26. $choicedatetime = explode(' - ',$choicedatetime);
  27. $starttime = strtotime($choicedatetime[0]);
  28. $endtime = strtotime($choicedatetime[1]) + 86399;
  29. }
  30. $this->view->assign('defaultdatetime',date('Y-m-d',$starttime).' - '.date('Y-m-d',$endtime));
  31. //dump($starttime);
  32. //dump($endtime);
  33. //所有应该参加考试的人
  34. $exam_paper = Db::name('exam_paper')->where('start_time','BETWEEN',[$starttime,$endtime])->where('deletetime',NULL)->column('id,user_ids');
  35. // dump($exam_paper);
  36. $new_exam_paper = [];
  37. foreach($exam_paper as $key => $val){
  38. $new_exam_paper = array_merge($new_exam_paper,explode(',',$val));
  39. }
  40. // dump($new_exam_paper);
  41. $new_exam_paper = array_count_values($new_exam_paper);
  42. // dump($new_exam_paper);
  43. //未通过考试的人
  44. $nopass = Db::name('exam_grade')->where('paper_id','IN',array_keys($exam_paper))->where('is_pass',0)->column('user_id');
  45. // dump($nopass);
  46. $nopass = array_count_values($nopass);
  47. // dump($nopass);
  48. //参加考试的人
  49. $exam_grade = Db::name('exam_grade')->where('paper_id','IN',array_keys($exam_paper))->column('user_id');
  50. // dump($exam_grade);
  51. $exam_grade = array_count_values($exam_grade);
  52. // dump($exam_grade);
  53. //应该参加培训的人
  54. $train_active = Db::name('train_active')->where('sign_endtime','BETWEEN',[$starttime,$endtime])->where('deletetime',NULL)->column('id,user_ids');
  55. // dump($train_active);
  56. $new_train_active = [];
  57. foreach($train_active as $key => $val){
  58. $new_train_active = array_merge($new_train_active,explode(',',$val));
  59. }
  60. // dump($new_train_active);
  61. $new_train_active = array_count_values($new_train_active);
  62. // dump($new_train_active);
  63. //参加签到的人
  64. $user_train = Db::name('user_train')->where('train_id','IN',array_keys($train_active))->column('user_id');
  65. // dump($user_train);
  66. $user_train = array_count_values($user_train);
  67. // dump($user_train);
  68. //所有用户
  69. $userlist = Db::name('user')->order('idcard_status desc')->select();
  70. foreach($userlist as $key => $user){
  71. $user['realname'] = '';
  72. if($user['idcard_status'] == 1){
  73. $user['realname'] = $user['nickname'];
  74. }
  75. //应参加考试次数
  76. $user['paper_count'] = isset($new_exam_paper[$user['id']]) ? $new_exam_paper[$user['id']] : 0;
  77. //不及格次数
  78. $user['no_pass'] = isset($nopass[$user['id']]) ? $nopass[$user['id']] : 0;
  79. //考试次数
  80. $user['grade_count'] = isset($exam_grade[$user['id']]) ? $exam_grade[$user['id']] : 0;
  81. //缺考次数
  82. $user['no_grade'] = $user['paper_count'] - $user['grade_count'];
  83. if($user['no_grade'] < 0){ $user['no_grade'] = 0;}
  84. //应该签到的次数
  85. $user['train_count'] = isset($new_train_active[$user['id']]) ? $new_train_active[$user['id']] : 0;
  86. //签到的次数
  87. $user['sign_count'] = isset($user_train[$user['id']]) ? $user_train[$user['id']] : 0;
  88. //未到的次数
  89. $user['no_sign'] = $user['train_count'] - $user['sign_count'];
  90. if($user['no_sign'] < 0){ $user['no_sign'] = 0;}
  91. //匿名用户
  92. if($user['idcard_status'] != 1){
  93. $user['no_pass'] = 0;
  94. $user['grade_count'] = 0;
  95. $user['no_grade'] = 0;
  96. $user['sign_count'] = 0;
  97. $user['no_sign'] = 0;
  98. }
  99. //
  100. $userlist[$key] = $user;
  101. }
  102. $this->assign('datalist',$userlist);
  103. $this->view->engine->layout(false);
  104. return $this->view->fetch();
  105. }
  106. }