利用PHPExcel如何读取表格的内容呢?话不多说,下面的这篇文章将给大家详细的介绍关于PHPExcel读取表格中内容的方法。

先引入类IOFactory.phprequire_once '../PHPExcel/IOFactory.php';

$filePath = "test.xlsx"; // 测试文件

加载测试文件$inputFileType = PHPExcel_IOFactory::identify($filePath) 判断文件类型

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

$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);

相关推荐:

php获取excel表格内容,利用PHPExcel如何读取表格中内容相关推荐

  1. php使用excel表格数据处理,使用php代码读取表格方法(一)PHPExcel类使用

    读取表格这个开发中经常遇到的事情,下面来介绍下使用PHPExcel来读取表格数据的例子,这里主要写下php处理表格那块的代码 $excel_file='./demo.xlsx'; //表格文件 $ex ...

  2. java如何画出表格_Java利用iText7画个性化表格

    Java利用iText7画个性化表格 Java利用iText7画个性化表格 有时PDF中会出现非传统等行等列表格,下面介绍如何画个性化表格 (需要安装iText7插件哦)(官网http://devel ...

  3. python如何逐行读取文件_Python逐行读取文件中内容的简单方法

    项目开发中文件的读写是必不可少的 下面来简单介绍一下文件的读 读文件,首先我们要有文件 那我首先自己创建了一个文本文件password.txt 内容如下: 下面先贴上代码,然后对其进一步解释: # c ...

  4. php导入excel源码,利用PHPExcel类库,实现PHP导出导入Excel表格Excel文件!

    [温馨提示]源码包解压密码:www.youhutong.com 利用PHPExcel类库,实现PHP导出导入Excel文件!(案例教程源码) 需要注意的地方就是: 1.导出文件时,如果你的字段过多,可 ...

  5. php写excel文件_利用PHPExcel实现Excel文件的写入和读取

    作为一个原本的Java党,用过PHP才知道,原来对于Excel文件的写入和读取原来可以这么简单! 利用PHP实现对于Excel的读取,主要借助于PHPExcel插件来完成. PHPExcel下载地址: ...

  6. php excel导出sheet表,phpexcel来做表格导出(多个工作sheet)

    1.先得去下载phpexcel文档,加压下来 /** * 简单实用Execl */ set_include_path('.'.get_include_path().PATH_SEPARATOR.dir ...

  7. php excel导入数组,利用PHPExcel导入xlsx/xls,将xlsx、xls转换为数组

    项目的原因有时候我们需要把xls的文件数据导入到数据库,今天青岛星网先跟大家分享:利用PHPExcel导入xlsx/xls,将xlsx.xls转换为数组的思路方法. 利用PHPExcel导入xlsx/ ...

  8. php实现生成word表格,TP5利用phpforword生成word表格文档

    TP5利用phpforword生成word表格文档 2019-12-18 573 1.首先用composer安装下载 phpoffice/phpforwordcomposer require phpo ...

  9. android读取bin文件内容,Android的NFC读取IsoDep文件内容

    我想看过一些资料出ISO/IEC 14443 A类卡.Android的NFC读取IsoDep文件内容 使用android应用程序分析卡片后,我发现应用程序(AID:15845F)具有我需要的特定文件( ...

最新文章

  1. 【Spring】事务控制API
  2. 【BZOJ1497】【NOI2006】最大获利
  3. linux 编译openmp,Linux 系统中OpenMP
  4. leveldb demo
  5. Chrome常用快捷键整理汇总
  6. java小数强制转换,Java中的强制类型转换 大数转小数
  7. 网宿科技与国汽智控达成战略合作 共推智能网联汽车技术落地
  8. apch连接mysql数据库连接_配置phpmyadmin连接远程 MySQL数据库
  9. android中一些常用的VIEW动作类型
  10. echo 在shell及脚本中显示色彩及闪烁警告效果
  11. svn 删除本地和远程仓库上的文件
  12. java中uri与url的区别_URL和URI的区别与总结
  13. 面试官:什么是TCP粘包?粘包原因?如何解决?
  14. 【零基础一起学习FPS游戏Unity3D手机游戏开发】第1章 准备工作
  15. 一线数据分析师教你如何写简历才能脱颖而出!
  16. Java解析X509证书代码
  17. 汽车IC TPS7A6633QDGNRQ1应用 低压降线性稳压器
  18. python编程实践(3):python+selenium实现12306抢票脚本
  19. Spring框架AOP原理及实现
  20. camera相关术语

热门文章

  1. 学了网络安全以后能做哪些岗位呢?来来来,带你们了解
  2. 009 Android之ContentProvider
  3. 记录 grafana登录 从 go 迁移到 php
  4. Servlet实现的个人所得税计算器
  5. 【PAT乙级】1092 最好吃的月饼 (20 分)
  6. Excel的加密和解密
  7. python统计单词频率、存放在字典中_Python3实现统计单词表中每个字母出现频率的方法示例...
  8. 柱底反力求和lisp软件_AutoLISP详细讲解
  9. sketch软件_Sketch软件怎么用?怎么提升Sketch软件技巧?
  10. java序列化和反序列化以及序列化ID的作用分析