PHP   发布时间:2022-04-04  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了php添加excel更新数据表数据大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

公司有个需求,是用excel更新数据的,把错误的行列放到一个数组返回出来,正常的数据则插入,且返回数量

 

1.先需要引入PHPspreadsheet,这里使用COR_159_11845@poser 安装

composer require PHPoffice/PHPspreadsheet

2.还需要在头部引入,命名空间自己根据vendor目录设置

use Exception;
use PHPOffice\PHPSpreadsheet\Cell\Coordinate;
use PHPOffice\PHPSpreadsheet\Reader\XLSX;
use PHPOffice\PHPSpreadsheet\Reader\Xls;
use PHPOffice\PHPSpreadsheet\Reader\Csv;

3.下面就是相关代码了,其实逻辑很简单,把excel导入的数据和数据表的字段拼接成二维数组,然后插入就行了

  /**
   * excel开启@L_801_15@
   * author: panzhide
   * @return array
   * Date: 2020/9/4
   */
  public function logisticsImportExcel()
  {
    $file = request()->file('file');
    if (!$filE) {
      return json_success('excel文件不能为空', 'file');
    }
    //将文件保存到public/storage/uploads/目录下面
    $savename = \think\Facade\Filesystem::disk('public')->putFile('uploads', $filE);

    //获取文件路径
    $filePath = getcwd() . '/storage/' . $savename;
    if (!is_file($filePath)) {
      return json_success('没有发现结果');
    }
    //实例化reader
    $ext = pathinfo($filePath, PATHINFO_EXTENSION);
    if (!in_array($ext, ['csv', 'xls', 'xLSX'])) {
      return json_success('未知的数据格式');
    }
    if ($ext === 'csv') {
      $file = fopen($filePath, 'r');
      $filePath = tempnam(sys_get_temp_dir(), 'import_csv');
      $fp = fopen($filePath, "w");
      $n = 0;
      while ($line = fgets($filE)) {
        $line = rtrim($line, "\n\r\0");
        $encoding = mb_detect_encoding($line, ['utf-8', 'gbk', 'latin1', 'big5']);
        if ($encoding != 'utf-8') {
          $line = mb_convert_encoding($line, 'utf-8', $encoding);
        }
        if ($n == 0 || preg_match('/^".*"$/', $linE)) {
          fwrite($fp, $line . "\n");
        } else {
          fwrite($fp, '"' . str_replace(['"', ','], ['""', '","'], $linE) . "\"\n");
        }
        $n++;
      }
      fclose($filE) || fclose($fp);

      $reader = new Csv();
    } elseif ($ext === 'xls') {
      $reader = new Xls();
    } else {
      $reader = new XLSX();
    }

    //导入文件首行类型,认是注释,如果需要使用字段名称使用Name
    $importHeadType = isset($this->importHeadTypE) ? $this->importHeadType : 'comment';
    //认的表名
    $table = OrderAddress::build()->getTable();

    $fieldArr = [];
    $list = Db::query('SHOW FULL columNS FROM `' . $table . '`');
    foreach ($list as $k => $v) {
      if ($importHeadType == 'comment') {
        $fieldArr[$v['Comment']] = $v['Field'];
      } else {
        $fieldArr[$v['Field']] = $v['Field'];
      }
    }

    //加载文件
    $insert = [];
    try {
      if (!$PHPExcel = $reader->load($filePath)) {
        return json_success('未知的数据格式');
      }
      $currentSheet = $PHPExcel->getSheet(0);  //读取文件中的第一个工作表
      $allcolumn = $currentSheet->getHighestDatacolumn(); //取得最大的列号
      $allRow = $currentSheet->getHighestRow(); //取得一共有多少行
      $maxcolumnnumber = Coordinate::columnIndexFromString($allcolumn);
      $fields = [];
      for ($currentRow = 1; $currentRow <= 1; $currentRow++) {
        for ($currentcolumn = 1; $currentcolumn <= $maxcolumnnumber; $currentcolumn++) {
          $val = $currentSheet->getCellBycolumnAndRow($currentcolumn, $currentRow)->getValue();
          $fields[] = $val;
        }
      }

      for ($currentRow = 2; $currentRow <= $allRow; $currentRow++) {
        $values = [];
        for ($currentcolumn = 1; $currentcolumn <= $maxcolumnnumber; $currentcolumn++) {
          $val = $currentSheet->getCellBycolumnAndRow($currentcolumn, $currentRow)->getValue();
          $values[] = is_null($val) ? '' : $val;
        }
        $row = [];
        $temp = array_combine($fields, $values);
        foreach ($temp as $k => $v) {
          if (isset($fieldArr[$k]) && $k !== '') {
            $row[$fieldArr[$k]] = $v;
          }
        }
        if ($row) {
          $insert[] = $row;
        }
      }
    } catch (Exception $exception) {
      return json_success($exception->getmessage());
    }

    if (!$insert) {
      return json_success('没有更新行');
    }

    $n = 0;
    foreach ($insert as $key => $value) {
      $n++;
      if (!$value['logistics_sn']) {
        $error[] = '第' . $n . '行物流编号不得为空';
      } else {
        $kuaiDicom_code = KuaiDicode::build()->where('name', $value['kuaiDicom'])->find();
        if (!$kuaiDicom_codE) {
          $error[] = '第' . $n . '行' . $value['kuaiDicom'] . '物流公司不支持';
        } else {
          $info = OrderAddress::build()->where('order_sn', $value['order_sn'])->find();
          if (!$info) {
            $error[] = '第' . $n . '行订单不存在';
          } else {
            $update_data['kuaiDicom_code'] = $kuaiDicom_code['code'];
            $update_data['update_time'] = time();
            $update_data['order_sn'] = $value['order_sn'];
            $update_data['kuaiDicom'] = $value['kuaiDicom'];
            $update_data['logistics_sn'] = $value['logistics_sn'];
            $update_data['id'] = $info['id'];
            $update_data_list[] = $update_data;
          }
        }
      }
    }
    $this->logisticsImportExcelupdate($update_data_list);
    $msg = '导入成功,共整合更新' . count($update_data_list) . '条订单数据';
    return json_success($msg, $error);
  }

  private function logisticsImportExcelupdate($update_data_list)
  {
    Db::startTrans();
    try {
      OrderAddress::build()->saveAll($update_data_list);
    } catch (\Exception $E) {
      Db::rollBACk();
      $msg = $e->getmessage();
      return json_success($msg);
    } catch (\Exception $E) {
      Db::rollBACk();
      return json_success($e->getmessage() . $e->getLine());
    }
    Db::commit();
  }
 

 

大佬总结

以上是大佬教程为你收集整理的php添加excel更新数据表数据全部内容,希望文章能够帮你解决php添加excel更新数据表数据所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: