excel 是广泛使用的办公软件之一,其中包含了大量的数据,比如商品价格表、订单信息表等等。而在很多情况下,我们需要从 excel 中提取数据进行处理,以便进行后续的数据分析、数据挖掘等操作。本文将介绍如何使用 php 从 excel 中查询数据。
一、准备工作
首先,我们需要安装 PHPExcel 库,以便在 PHP 中读取 Excel 文件。PHPExcel 是一个 PHP 类库,用于读写 Excel 文件,支持多种Excel格式。要安装 PHPExcel 库,请同学们在命令行下执行以下命令:
composer require phpoffice/phpexcel
安装完成后,在 PHP 文件中引入 PHPExcel 类文件:
require 'vendor/autoload.php';
接下来,我们需要准备一个 Excel 文件,假设它的路径为 /var/www/excel/data.xlsx,其中包含了一个工作表 sheet1,数据如下图所示:
立即学习“PHP免费学习笔记(深入)”;

二、查询数据
有了准备工作后,我们就可以使用 PHPExcel 库来查询数据了。具体步骤如下:
1、实例化 PHPExcel 类:
$objPHPExcel = new PHPExcel();
2、加载 Excel 文件:
$objReader = PHPExcel_IOFactory::createReader('Excel2007');
$objPHPExcel = $objReader->load('/var/www/excel/data.xlsx');其中,Excel2007 表示读取 Excel 2007 及以上版本的文件,如果需要读取其他版本的 Excel 文件,请参考官方文档。
3、获取工作表:
$sheet = $objPHPExcel->getActiveSheet();
4、获取行数和列数:
$rowCount = $sheet->getHighestRow(); //行数 $columnCount = $sheet->getHighestColumn(); //列数 $columnCount = PHPExcel_Cell::columnIndexFromString($columnCount);
其中,PHPExcel_Cell::columnIndexFromString() 方法用于将 Excel 列名称转换成列索引,从而获取列数。
5、遍历工作表,获取数据:
$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;
    }
}以上代码中,我们通过嵌套 for 循环,遍历工作表的每一行和每一列,然后使用 getCellByColumnAndRow() 方法获取单元格的值,并将其存储到 $data 数组中,最后得到的 $data 数组结构如下:
array(
    array('姓名', '年龄', '性别'),
    array('张三', 20, '男'),
    array('李四', 25, '女'),
    array('王五', 30, '男'),
)这样,我们就可以从 Excel 中查询数据了。
三、示例代码
以上是从 Excel 查询数据的具体步骤,下面给出完整的示例代码,供同学们参考:
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) "男"
  }
}四、总结
本文介绍了如何使用 PHPExcel 库从 Excel 中查询数据,具体步骤为:实例化 PHPExcel 类、加载 Excel 文件、获取工作表、获取行数和列数、遍历工作表,获取数据。通过本文的介绍,同学们可以掌握从 Excel 中获取数据的基本方法。
以上就是如何使用 PHP 从 Excel 中查询数据的详细内容,更多请关注php中文网其它相关文章!
                        
                        全网最新最细最实用WPS零基础入门到精通全套教程!带你真正掌握WPS办公! 内含Excel基础操作、函数设计、数据透视表等
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号