如何使用 PHP 从 Excel 中查询数据
时间:2023-04-26 14:52
Excel 是广泛使用的办公软件之一,其中包含了大量的数据,比如商品价格表、订单信息表等等。而在很多情况下,我们需要从 Excel 中提取数据进行处理,以便进行后续的数据分析、数据挖掘等操作。本文将介绍如何使用 PHP 从 Excel 中查询数据。 一、准备工作 首先,我们需要安装 PHPExcel 库,以便在 PHP 中读取 Excel 文件。PHPExcel 是一个 PHP 类库,用于读写 Excel 文件,支持多种Excel格式。要安装 PHPExcel 库,请同学们在命令行下执行以下命令: 安装完成后,在 PHP 文件中引入 PHPExcel 类文件: 接下来,我们需要准备一个 Excel 文件,假设它的路径为 /var/www/excel/data.xlsx,其中包含了一个工作表 sheet1,数据如下图所示: 二、查询数据 有了准备工作后,我们就可以使用 PHPExcel 库来查询数据了。具体步骤如下: 1、实例化 PHPExcel 类: 2、加载 Excel 文件: 其中,Excel2007 表示读取 Excel 2007 及以上版本的文件,如果需要读取其他版本的 Excel 文件,请参考官方文档。 3、获取工作表: 4、获取行数和列数: 其中,PHPExcel_Cell::columnIndexFromString() 方法用于将 Excel 列名称转换成列索引,从而获取列数。 5、遍历工作表,获取数据: 以上代码中,我们通过嵌套 for 循环,遍历工作表的每一行和每一列,然后使用 getCellByColumnAndRow() 方法获取单元格的值,并将其存储到 $data 数组中,最后得到的 $data 数组结构如下: 这样,我们就可以从 Excel 中查询数据了。 三、示例代码 以上是从 Excel 查询数据的具体步骤,下面给出完整的示例代码,供同学们参考: 输出结果如下: 四、总结 本文介绍了如何使用 PHPExcel 库从 Excel 中查询数据,具体步骤为:实例化 PHPExcel 类、加载 Excel 文件、获取工作表、获取行数和列数、遍历工作表,获取数据。通过本文的介绍,同学们可以掌握从 Excel 中获取数据的基本方法。 以上就是如何使用 PHP 从 Excel 中查询数据的详细内容,更多请关注Gxl网其它相关文章!composer require phpoffice/phpexcel
require 'vendor/autoload.php';
$objPHPExcel = new PHPExcel();
$objReader = PHPExcel_IOFactory::createReader('Excel2007');$objPHPExcel = $objReader->load('/var/www/excel/data.xlsx');
$sheet = $objPHPExcel->getActiveSheet();
$rowCount = $sheet->getHighestRow(); //行数$columnCount = $sheet->getHighestColumn(); //列数$columnCount = PHPExcel_Cell::columnIndexFromString($columnCount);
$data = array();for ($rowIndex = 1; $rowIndex <= $rowCount; $rowIndex++) { for ($columnIndex = 0; $columnIndex < $columnCount; $columnIndex++) { $cellValue = $sheet->getCellByColumnAndRow($columnIndex, $rowIndex)->getValue(); $data[$rowIndex-1][$columnIndex] = $cellValue; }}
array( array('姓名', '年龄', '性别'), array('张三', 20, '男'), array('李四', 25, '女'), array('王五', 30, '男'),)
require 'vendor/autoload.php';$objReader = PHPExcel_IOFactory::createReader('Excel2007');$objPHPExcel = $objReader->load('/var/www/excel/data.xlsx');$sheet = $objPHPExcel->getActiveSheet();$rowCount = $sheet->getHighestRow();$columnCount = $sheet->getHighestColumn();$columnCount = PHPExcel_Cell::columnIndexFromString($columnCount);$data = array();for ($rowIndex = 1; $rowIndex <= $rowCount; $rowIndex++) { for ($columnIndex = 0; $columnIndex < $columnCount; $columnIndex++) { $cellValue = $sheet->getCellByColumnAndRow($columnIndex, $rowIndex)->getValue(); $data[$rowIndex-1][$columnIndex] = $cellValue; }}var_dump($data);
array(4) { [0]=> array(3) { [0]=> string(6) "姓名" [1]=> string(6) "年龄" [2]=> string(6) "性别" } [1]=> array(3) { [0]=> string(6) "张三" [1]=> float(20) [2]=> string(3) "男" } [2]=> array(3) { [0]=> string(6) "李四" [1]=> float(25) [2]=> string(3) "女" } [3]=> array(3) { [0]=> string(6) "王五" [1]=> float(30) [2]=> string(3) "男" }}