Jjhc.php 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <?php
  2. namespace app\job;
  3. use app\common\api\BatchApi;
  4. use app\common\api\TalentLogApi;
  5. use app\common\model\TalentChecklog;
  6. use app\common\state\ProjectState;
  7. use think\queue\Job;
  8. use think\facade\Log;
  9. use think\facade\Db;
  10. use app\common\api\ChuanglanSmsApi;
  11. // 给类文件的命名空间起个别名
  12. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  13. //Xlsx类 保存文件功能类
  14. use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
  15. use app\admin\api\DataApi;
  16. class Jjhc {
  17. public function fire(Job $job, $data) {
  18. if ($this->deal($data)) {
  19. Log::info(json_encode($data));
  20. $job->delete();
  21. return true;
  22. }
  23. Log::error(json_encode($data));
  24. if ($job->attempts() >= 3) {
  25. $job->delete();
  26. return false;
  27. }
  28. $job->release(10); //10秒后重试
  29. }
  30. /**
  31. * 处理业务逻辑
  32. * @param type $data
  33. * @return bool
  34. */
  35. public function deal($data): bool {
  36. switch ($data['type']){
  37. case '1':
  38. $path = dirname(dirname(dirname(__FILE__)));
  39. $spreadsheet = \PhpOffice\PhpSpreadsheet\IOFactory::load($path . "/test.xlsx");
  40. $sheet = $spreadsheet->getSheet(0);
  41. $datas = $sheet->toArray();
  42. $writer = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($spreadsheet, 'Xlsx');
  43. $dataapi = new DataApi();
  44. for ($index = 0; $index <= count($datas); $index++) {
  45. echo "正在查询第" . ($index + 1) . "人({$datas[$index][3]})的失业险\r\n";
  46. $res = $dataapi->queryUnemploymentInsuranceByIdAndTime($datas[$index][3],'202201','202301');
  47. if($res){
  48. $i = 0;
  49. $months = [];
  50. if(count($res['data']) > 0){
  51. foreach ($res['data'] as $k => $v){
  52. if(strpos($v['AAB069'],"晋华") !== false || strpos($v['AAB069'],"渠梁") !== false){
  53. $i++;
  54. array_push($months,$v['AAE003']);
  55. }
  56. }
  57. sort($months);
  58. $res_str = "2022年共缴费{$i}个月,分别是:".implode('、',$months);
  59. }else{
  60. $res_str = "2022年共缴费0个月";
  61. }
  62. echo "第". ($index + 1) . "失业险整理完毕,姓名:{$datas[$index][1]},".$res_str."\r\n";
  63. $sheet->setCellValue('F' . ($index+1), $res_str);
  64. }
  65. sleep(2);
  66. }
  67. $writer->save($path . "/test.xlsx");
  68. return false;
  69. break;
  70. case '2':
  71. return false;
  72. $path = dirname(dirname(dirname(__FILE__)));
  73. $spreadsheet = \PhpOffice\PhpSpreadsheet\IOFactory::load($path . "/test.xlsx");
  74. $sheet = $spreadsheet->getSheet(0);
  75. $datas = $sheet->toArray();
  76. $writer = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($spreadsheet, 'Xlsx');
  77. $dataapi = new DataApi();
  78. for ($index = 0; $index < count($datas); $index++) {
  79. echo "正在查询第" . ($index+1) . "人({$datas[$index][3]})的养老险\r\n";
  80. $res = $dataapi->queryOldAgeSecurityInsuranceByIdAndTime($datas[$index][3],'202201','202212');
  81. if($res){
  82. $i = 0;
  83. $months = [];
  84. if(count($res['data']) > 0){
  85. foreach ($res['data'] as $k => $v){
  86. if(strpos($v['AAB004'],"晋华") !== false || strpos($v['AAB004'],"渠梁") !== false){
  87. $i++;
  88. array_push($months,$v['AAE003']);
  89. }
  90. }
  91. sort($months);
  92. $res_str = "2022年共缴费{$i}个月,分别是:".implode('、',$months);
  93. }else{
  94. $res_str = "2022年共缴费0个月";
  95. }
  96. echo "第". ($index + 1) . "养老险整理完毕,姓名:{$datas[$index][1]},".$res_str."\r\n";
  97. $sheet->setCellValue('E' . ($index+1), $res_str);
  98. }
  99. sleep(2);
  100. }
  101. $writer->save($path . "/test.xlsx");
  102. return false;
  103. break;
  104. case '3':
  105. $path = dirname(dirname(dirname(__FILE__)));
  106. $spreadsheet = \PhpOffice\PhpSpreadsheet\IOFactory::load($path . "/test1.xlsx");
  107. $sheet = $spreadsheet->getSheet(0);
  108. $datas = $sheet->toArray();
  109. $writer = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($spreadsheet, 'Xlsx');
  110. $dataapi = new DataApi();
  111. for ($index = 0; $index < count($datas); $index++) {
  112. echo "正在查询第" . ($index+1) . "人({$datas[$index][3]})的医保\r\n";
  113. $res = $dataapi->queryJfhbxxByYears($datas[$index][3],$datas[$index][1],'2022');
  114. if($res){
  115. $i = 0;
  116. $months = [];
  117. if(count($res['datalist']) > 0){
  118. foreach ($res['datalist'] as $k => $v){
  119. if( $v['aae140'] == '310'){
  120. $i++;
  121. array_push($months,$v['zmny00']);
  122. }
  123. }
  124. sort($months);
  125. $res_str = "2022年共缴费{$i}个月,分别是:".implode('、',$months);
  126. }else{
  127. $res_str = "2022年共缴费0个月";
  128. }
  129. echo "第". ($index + 1) . "医保整理完毕,姓名:{$datas[$index][1]},".$res_str."\r\n";
  130. $sheet->setCellValue('E' . ($index+1), $res_str);
  131. }
  132. sleep(2);
  133. }
  134. $writer->save($path . "/test1.xlsx");
  135. return false;
  136. break;
  137. default:
  138. return false;
  139. }
  140. }
  141. }