php处理Excel步骤介绍
遇到问题
平时在工作中,时常会出现将数据库表导出为Excel或者将Excel导入数据库表的需求。这一需求早早就已经实现过了,为了方便导入导出,兄弟连www.lampbrother.net将其分装成了两个方法作为记录。
代码实现
phpexcel类库的引用
phpexcel拥有强大的Excel处理能力,在packagist上已经拥有数百万次的下载量,不过实话实说,excel的处理速度仍然是非常慢,数据量较大时慎重使用。在packagist上下载或者直接用composer require phpoffice/phpexcel之后,便可以使用phpexcel了。
导出成为Excel
在绝大多数情况下,导出excel其实就是将二位数组转化为表格。
use namespace PHPExcel;
/**
* @param $name string 要保存的Excel的名字
* @param $ret_data 转换为表格的二维数组
* @throws PHPExcel_Exception
* @throws PHPExcel_Reader_Exception
*/
function exportExcel($name, $ret_data){
$objPHPExcel = new PHPExcel();
//设置表格
$objPHPExcel->getProperties()->setCreator($name)
->setLastModifiedBy($name)
->setTitle("Office 2007 XLSX Test Document")
->setSubject("Office 2007 XLSX Test Document")
->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.")
->setKeywords("office 2007 openxml php")
->setCategory("Test result file");
//填充数据
foreach ($ret_data as $key => $row) {
$num = $key + 1;
//$row = array_values($row);
$i=0;
foreach ($row as $key2 => $value2) {
$objPHPExcel->setActiveSheetIndex(0)->setCellValue( Cell::stringFromColumnIndex($i). ($num), $value2);
$i++;
}
}
//设置表格并输出
$objPHPExcel->getActiveSheet()->setTitle($name);
header('Content-Type: application/vnd.ms-excel');
header("Content-Disposition: attachment;filename={$name}.xls");
header('Cache-Control: max-age=0');
header('Cache-Control: max-age=1');
header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT');
header('Cache-Control: cache, must-revalidate');
header('Pragma: public'); // HTTP/1.0
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('php://output');
exit;
}
导入Excel
同理,导入Excel其实就是将Excel的数据转化成为二维数组,这就要求Excel必须符合格式。
function getRows($inputFileName)
{
if (!file_exists($inputFileName)) {
throw new Exception("File not existed");
}
$inputFileType = PHPExcel_IOFactory::identify($inputFileName);
$objReader = PHPExcel_IOFactory::createReader($inputFileType);
$objPHPExcel = $objReader->load($inputFileName);
$objWorksheet = $objPHPExcel->getActiveSheet();
$highestRow = $objWorksheet->getHighestRow();
$highestColumn = $objWorksheet->getHighestColumn();
$highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn);//总列数
$row = 1;
$curr = array();
while ($row <= $highestRow) {
for ($col = 0; $col < $highestColumnIndex; $col++) {
$value = str_replace(array("\n", "\n\r", "\r"), "", $objWorksheet->getCellByColumnAndRow($col, $row)->getValue());
$curr[$row][] = $value;
}
$row++;
}
array_shift($curr);//第一行一般是字段名(Excel中列的标题),导入时要移除
return $curr;
}
其他
导出时保存的格式是xlsx,想要改成其他格式需要传入不同的参数。
导入时如果有多个sheet时需要在上次打开时在要导入的sheet页(以保证当前sheet为activeSheet)关闭,或者根据sheet名在程序中选择sheet。
分享到:
相关推荐
PHP-Excel库(也称为PHPExcel)是一个开源项目,它提供了处理Excel文件的强大功能。它支持多种Excel文件格式,包括.BIFF (Excel 97-2003)、.XLSX (Excel 2007及以上版本) 和.OOCB (Open Office Calc Binary)。通过...
本文将详细介绍如何使用PHP来读取Excel文件,并介绍一个方便易用的PHP类库。我们将探讨基本概念、类库的选择、类的使用方法以及示例代码。 首先,我们需要了解Excel文件的格式。早期版本的Excel(.xls)文件使用...
通常,这个文件会包含如何实例化读者对象,打开Excel文件,遍历工作表,以及获取和处理单元格数据的步骤。例如,它可能包含以下基本流程: 1. 包含`excel_reader2.php`库:`require_once 'excel_reader2.php';` 2. ...
在PHP开发中,有时我们需要处理数据的导出功能,特别是生成Excel文件,这对于数据分析、报告制作等场景非常有用。"php根据excel模板导出excel并合并单元格"这个主题涉及了如何利用PHP来读取Excel模板,填充数据,并...
以PHPSpreadsheet为例,你可以通过以下步骤创建一个包含图片的Excel文件: 1. **安装PHPSpreadsheet**:通过Composer(PHP的依赖管理工具)添加`composer require phpoffice/phpspreadsheet`。 2. **创建工作簿和...
### PHP MySQL Excel 乱码终极处理 #### 一、乱码产生的根本原因 在进行PHP开发过程中,尤其是在处理Excel文件并将其数据导入MySQL数据库时,经常会遇到乱码问题。这主要是由于不同环节间的字符编码不统一所导致的...
本文将详细介绍如何使用PHP来读取Excel文件,通过一个简单的实例来展示其实现过程,这对于任何需要在PHP后端处理Excel数据的开发者来说都是十分有用的。 首先,我们要了解的是,PHP本身并不直接支持读取Excel文件,...
8. **示例代码**:在博客中,作者可能提供了使用`excel_class.php`的示例代码,展示了如何打开文件、读取数据、写入数据、保存文件等步骤。 由于没有具体的内容可供参考,这里只能提供一般性的介绍。如果想要了解更...
9. **示例代码**:`demo.php`文件中应包含上述步骤的完整实现,你可以参考并修改以适应自己的需求。 通过这个教程,你应该能理解如何使用PHP和phpspreadsheet库来创建带有图片的Excel文件,并解决可能的乱码问题。...
这些代码可能包含了如何打开Excel文件,读取工作表,将数据转换为数组,以及如何处理这些数据的基本步骤。 例如,一个基本的流程可能如下: 1. **引入库**:通过`require_once 'path/to/Spreadsheet_Excel_Reader....
1. **导出MySQL到Excel**:先通过SQL查询获取数据库中的数据,然后用PHP将数据写入Excel文件,过程类似于上述的导出步骤。 2. **导入Excel到MySQL**:上传Excel文件,读取数据,然后批量插入或更新数据库。注意处理...
【标题】:“php读取excel文件” 在PHP中读取Excel文件是一项常见的任务,...在实际应用中,可以根据具体需求进行调整,例如支持更广泛的Excel文件格式(如.xlsx),优化数据处理性能,或者增加数据验证和清洗步骤。
首先,PHP可以通过各种库来实现对Excel文件的操作,例如`PHPExcel`,这是PHP处理Excel文档的一个强大库,支持多种文件格式,如`.xls`、`.xlsx`等。在提供的文件列表中,`PHPExcel.php`是这个库的核心文件,包含了...
当我们需要处理Excel数据时,PHP提供了一些库来方便我们直接读取和操作Excel文件,而无需通过导入数据库这一中间步骤。这样的做法可以提高效率,减少资源消耗,尤其在处理大量数据时更为实用。 标题中的"php读取...
导入Excel文件通常涉及以下步骤: 1. 使用PHPExcel加载Excel文件:通过`PHPExcel_IOFactory`类的`load()`方法,可以加载Excel文件到PHP内存中。 2. 遍历数据:使用`getActiveSheet()`获取活动工作表,然后通过`...
在本篇文章中,我们将探讨如何使用 PHP 生成 Excel 文件,并介绍相关的知识点。 一、PHP header() 函数 PHP 的 header() 函数是生成 Excel 文件的关键。header() 函数用于发送 HTTP 头信息,告知浏览器如何处理下...
这篇教程将详细介绍如何使用PHP实现从MySQL数据库导出数据到Excel文件。 首先,我们需要理解基本的流程。这个过程通常包括以下几个步骤: 1. **连接MySQL数据库**:使用PHP的`mysqli_connect`或`PDO`函数建立与...
这篇博客“PHP生成excel文件”可能介绍了如何利用PHP创建和操作Excel文件,这对于数据分析、报表生成或用户下载功能非常有用。 生成Excel文件在PHP中最常见的库是PHPExcel和its newer version,叫做phpspreadsheet...
在PHP开发中,有时我们需要处理来自用户上传的Excel文件,例如收集数据、分析或存储到数据库。`php导入excel`这个主题就是关于如何在PHP环境中读取和处理Excel文件的知识点。下面将详细介绍如何实现这一功能,以及...
要使用PHPSpreadsheet库生成Excel文件并保存到特定目录,你需要按照以下步骤操作: 1. **安装库**:首先,通过Composer(PHP的依赖管理工具)安装PHPSpreadsheet。在命令行中运行: ``` composer require ...