• 技术文章 >后端开发 >php教程

    利用PHPExcel如何读取表格中内容

    不言不言2018-07-20 17:26:29原创1812
    利用PHPExcel如何读取表格的内容呢?话不多说,下面的这篇文章将给大家详细的介绍关于PHPExcel读取表格中内容的方法。

    先引入类IOFactory.php

    require_once '../PHPExcel/IOFactory.php';
    $filePath = "test.xlsx";  // 测试文件

    加载测试文件

    1. $inputFileType = PHPExcel_IOFactory::identify($filePath) 判断文件类型

    2. $objReader = PHPExcel_IOFactory::createReader($inputFileType); 实例化类型对象

    3. $objPHPExcel = $objReader->load($filePath); 加载文件

    下面主要判断Excel2007和Excel5类型,即xlsx/xlsm/xltx/xltm和xls/xlt格式文件

    try {
        $inputFileType = PHPExcel_IOFactory::identify($filePath);
        if ($inputFileType !== "Excel5" && $inputFileType !== "Excel2007" ) {
            unlink($filePath) && str_alert(-1,"请确保导入的文件格式正确!");
        }
        $objReader = PHPExcel_IOFactory::createReader($inputFileType);
        $objPHPExcel = $objReader->load($filePath);
    } catch(Exception $e) {
        unlink($filePath) && str_alert(-1,'加载文件发生错误:”'.pathinfo($filePath,PATHINFO_BASENAME).'”: '.$e->getMessage());
        }

    获取当前工作表

    $sheet = $objPHPExcel->getSheet(0);
    //或者
    $sheet = $objPHPExcel->getActiveSheet();

    获取工作表行数和列数

    $highestRow = $sheet->getHighestRow();
    $highestColumn = $sheet->getHighestColumn();

    注意:有时候你会发现你的表格明明有内容的行数就5行,但是获取到的$highestRow却有7,8行或者更多,这可能是因为你在操作你的表格的时候不小心点击了其它行数,虽然没有填写内容,但getHighestRow也是能够识别出行数;
    想要获取有内容的行数应该使用getHighestDataRow和getHighestDataColumn
    源码注释是这样介绍的string Highest row number that contains data,即包含数据的字符串最高行数.

    单元格具体内容

    xlsx类型的表格单元格是通过类似xy轴坐标来获取的,

    可通过类似

     $sheet->getCell("A1")->getValue();
     $sheet->getCell("B2")->getValue();

    获取相应位置的内容,
    如果不想通过字母了来遍历获取,可以用数字索引方法

      $sheet->getCellByColumnAndRow(0,1);
      $sheet->getCellByColumnAndRow(1,2);

    注意坐标中第一个参数从0开始,0代表A,1代表B...,第二个参数从1开始.
    下面是遍历表格获取全部单元格内容:

    $dataSet=array();
    for ($column = "A"; $column <= $highestColumn; $column++) {//列数是以A列开始
        for ($row = 4; $row <= $highestRow; $row++) { //行数是以第4行开始
            $cell = $sheet->getCell($column . $row)->getValue();
            if($cell instanceof PHPExcel_RichText) { //富文本转换字符串
                $cell = $cell->__toString();
            }
            $dataSet[$row][] = $cell;
        }
    }

    其中富文本转换字符串,是使用$cell instanceof PHPExcel_RichText判断是否为富文本,查阅资料发现如果你的单元格中字符串包含两种以上的字体会自动被设为富文本,这时候需要__toString()转换

    判断合并单元格是否位于最左上角

    当我们循环输出所有单元格后发现,一些被合并的单元格只有最左上坐标的是有内容的,其他都是null
    例如A4,A5合并成一个单元格,getCell("A4")是有正常内容的,但是getCell("A5")是null.
    isMergeRangeValueCell可以用来判断某个具体的单元格是否为最左上角

    $sheet->getCell('A' . $row)->isMergeRangeValueCell()

    当$row为4的时候是返回true,5的时候返回false

    转换时间

    获取表格中时间格式的内容,需要PHPExcel_Shared_Date::ExcelToPHP()来转换为php可识别的时间格式

    date('Y-m-d',PHPExcel_Shared_Date::ExcelToPHP($sometime);

    相关推荐:

    phpexcel读取excel表格时间的例子

    PHPExcel正确读取excel表格时间单元格

    以上就是利用PHPExcel如何读取表格中内容的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:php
    上一篇:PHP实现非阻塞以及多线程编程 下一篇:PHP队列算法如何实现?
    大前端线上培训班

    相关文章推荐

    • 推荐一本PHP程序猿都应该拜读的书_PHP• Thinkphp关闭缓存的方法_php实例• php实现图片添加水印功能_php实例• PHP命名空间(Namespace)的使用详解_php实例• 请问一个PHP安装程序的小疑点

    全部评论我要评论

  • 彭伟

    文本框里面的内容可以读出来吗

    2020-10-15

  • 取消发布评论发送
  • 1/1

    PHP中文网