execl_loader.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. <?php
  2. namespace bank;
  3. require_once(BASE_ROOT_PATH . '/vendor/autoload.php');
  4. use PhpOffice;
  5. use Log;
  6. function file_generator($path)
  7. {
  8. if (!file_exists($path)) {
  9. return;
  10. }
  11. $fd = opendir($path);
  12. if ($fd)
  13. {
  14. while (($item = @readdir($fd)) !== false)
  15. {
  16. $sub = $path . DIRECTORY_SEPARATOR . $item;
  17. if (is_dir($sub) && $item != '.' && $item != '..')
  18. {
  19. $files = file_generator($sub);
  20. foreach ($files as $file) {
  21. yield $file;
  22. }
  23. }
  24. elseif (is_file($sub)) {
  25. yield $sub;
  26. }
  27. }
  28. }
  29. closedir($fd);
  30. }
  31. class execl_loader
  32. {
  33. public function load_dirs($dirs)
  34. {
  35. foreach ($dirs as $dir) {
  36. $this->load_dir($dir);
  37. }
  38. }
  39. public function load_dir($dir)
  40. {
  41. $files = file_generator($dir);
  42. foreach ($files as $file) {
  43. Log::record("$file",Log::DEBUG);
  44. $this->load_file($file);
  45. }
  46. }
  47. public function load_file($file)
  48. {
  49. $line_reader = function ($file)
  50. {
  51. $ext = pathinfo($file,PATHINFO_EXTENSION);
  52. if(!in_array($ext,['xls','xlsx'])) {
  53. return;
  54. }
  55. $reader = PhpOffice\PhpSpreadsheet\IOFactory::createReaderForFile($file);
  56. $reader->setReadDataOnly(true);
  57. $spreadsheet = PhpOffice\PhpSpreadsheet\IOFactory::load($file);
  58. yield 'start' => 1;
  59. foreach ($spreadsheet->getWorksheetIterator() as $worksheet)
  60. {
  61. foreach ($worksheet->getRowIterator() as $row)
  62. {
  63. $cellIterator = $row->getCellIterator();
  64. $cellIterator->setIterateOnlyExistingCells(false); // Loop all cells, even if it is not set
  65. $item = [];
  66. foreach ($cellIterator as $cell)
  67. {
  68. if ($cell !== null) {
  69. $item[] = trim($cell->getFormattedValue());
  70. }
  71. }
  72. yield 'line' => $item;
  73. }
  74. }
  75. yield 'start' => 0;
  76. };
  77. $mod_record = Model();
  78. $inserter = function ($line) use ($mod_record){
  79. $mod_record->table('bank_record')->insert($line);
  80. };
  81. $lines = $line_reader($file);
  82. $convert = new converter();
  83. foreach ($lines as $key => $val)
  84. {
  85. if($key === 'start') {
  86. $convert->start();
  87. }
  88. elseif($key === 'line')
  89. {
  90. $line = $convert->convert($val);
  91. if(!empty($line) && !empty($line['trade_no'])) {
  92. $inserter($line);
  93. }
  94. else {
  95. Log::record(json_encode($val,JSON_UNESCAPED_UNICODE),Log::DEBUG);
  96. }
  97. }
  98. else {
  99. $convert->end();
  100. }
  101. }
  102. }
  103. }