• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    PHPExcel实现的读取多工作表操作示例

    本文实例讲述了PHPExcel实现的读取多工作表操作。分享给大家供大家参考,具体如下:

    最近我们公司crm模块需要优化一下客户导入功能,之前的要求是:只需要从单个工作表中获取数据;现在的要求是:需要在多个工作表中获取对应数据,并导入数据库;

    幸亏PHPExcel已经给我们提供了获取多个sheet工作表的方法。下面直接上代码:【这里我用的是tp3.2.3】

    /**
     * 导入excel文件
     * @param string $file excel文件路径
     * @return array    excel文件内容数组
     */
    function import_excel($file){
      // 判断文件是什么格式
      $type = pathinfo($file); 
      $type = strtolower($type["extension"]);
      if ($type=='xlsx') { 
        $type='Excel2007'; 
      }elseif($type=='xls') { 
        $type = 'Excel5'; 
      } 
      ini_set('max_execution_time', '0');
      Vendor('PHPExcel.PHPExcel');
      $objReader = PHPExcel_IOFactory::createReader($type);//判断使用哪种格式
      $objReader ->setReadDataOnly(true); //只读取数据,会智能忽略所有空白行,这点很重要!!!
      $objPHPExcel = $objReader->load($file); //加载Excel文件
      $sheetCount = $objPHPExcel->getSheetCount();//获取sheet工作表总个数
      $rowData = array();
      $RowNum = 0;
      /*读取表格数据*/
      for($i =0;$i = $sheetCount-1;$i++){//循环sheet工作表的总个数
        $sheet = $objPHPExcel->getSheet($i);
        $highestRow = $sheet->getHighestRow();
        $RowNum += $highestRow-1;//计算所有sheet的总行数
        $highestColumn = $sheet->getHighestColumn();
        //从第$i个sheet的第1行开始获取数据
        for($row = 1;$row = $highestRow;$row++){
          //把每个sheet作为一个新的数组元素 键名以sheet的索引命名 利于后期数组的提取
          $rowData[$i][] = arrToOne($sheet->rangeToArray('A' . $row . ':' . $highestColumn . $row, NULL, TRUE, FALSE));
        }
      }
      /*删除每行表头数据*/
      foreach($rowData as $k=>$v){
        array_shift($rowData[$k]);
      }
      echo 'pre>';
      print_r($rowData);//打印结果
      echo '/pre>';
      return array("RowNum" => $RowNum,"Excel_Data" => $rowData);
    }
    
    

    Excel截图如下:

    打印结果如下:0对应第一个sheet;以此类推第3个就是最后一个sheet;

    注意:当某一个sheet不存在任何数据时,我这里会创建该元素为空数组,比如下面结果的第3个元素 ;所以在插入数据库操作的时候需要再判断一下是否为空!

    pre>Array
    (
        [0] => Array
            (
                [0] => Array
                    (
                        [0] => 测试数据001
                        [1] =>
                        [2] => 联系人1
                        [3] => 女
                        [4] =>
                        [5] =>
                        [6] =>
                        [7] =>
                        [8] =>
                        [9] =>
                        [10] =>
                        [11] =>
                        [12] =>
                    )
     
                [1] => Array
                    (
                        [0] => 测试数据002
                        [1] =>
                        [2] => 联系人2
                        [3] => 女
                        [4] =>
                        [5] =>
                        [6] =>
                        [7] =>
                        [8] =>
                        [9] =>
                        [10] =>
                        [11] =>
                        [12] =>
                    )
     
            )
     
        [1] => Array
            (
                [0] => Array
                    (
                        [0] => 测试数据014
                        [1] =>
                        [2] => 联系人13
                        [3] => 女
                        [4] =>
                        [5] =>
                        [6] =>
                        [7] =>
                        [8] =>
                        [9] =>
                        [10] =>
                        [11] =>
                        [12] =>
                    )
     
            )
     
        [2] => Array
            (
                [0] => Array
                    (
                        [0] => 测试数据015
                        [1] =>
                        [2] => 联系人13
                        [3] => 女
                        [4] =>
                        [5] =>
                        [6] =>
                        [7] =>
                        [8] =>
                        [9] =>
                        [10] =>
                        [11] =>
                        [12] =>
                    )
     
            )
     
        [3] => Array
            (
            )
     
    )
    /pre>

    至此, 以上就成功获取到了每一个sheet的数据;

    PS:关于PHPExcel文件可至此下载 https://www.jb51.net/codes/194070.html。

    更多关于PHP相关内容感兴趣的读者可查看本站专题:《php操作office文档技巧总结(包括word,excel,access,ppt)》、《PHP数组(Array)操作技巧大全》、《PHP数据结构与算法教程》、《php程序设计算法总结》、《PHP数学运算技巧总结》、《php正则表达式用法总结》、《php字符串(string)用法总结》及《php常见数据库操作技巧汇总》

    希望本文所述对大家PHP程序设计有所帮助。

    您可能感兴趣的文章:
    • PHP读取Excel内的图片(phpspreadsheet和PHPExcel扩展库)
    • PHPExcel实现表格导出功能示例【带有多个工作sheet】
    • 使用PHPExcel导出Excel表
    • Thinkphp5+PHPExcel实现批量上传表格数据功能
    • PHPExcel冻结(锁定)表头的简单实现方法
    • 使用PHPExcel实现数据批量导出为excel表格的方法(必看)
    • thinkPHP+phpexcel实现excel报表输出功能示例
    • php通过PHPExcel导入Excel表格到MySQL数据库的简单实例
    上一篇:ThinkPHP 框架实现的读取excel导入数据库操作示例
    下一篇:php操作redis常见方法示例【key与value操作】
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    PHPExcel实现的读取多工作表操作示例 PHPExcel,实现,的,读取,多工,