`
itxdl
  • 浏览: 26841 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

php处理Excel步骤介绍

PHP 
阅读更多
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 在线Excel编辑

    PHP-Excel库(也称为PHPExcel)是一个开源项目,它提供了处理Excel文件的强大功能。它支持多种Excel文件格式,包括.BIFF (Excel 97-2003)、.XLSX (Excel 2007及以上版本) 和.OOCB (Open Office Calc Binary)。通过...

    php读取excel类

    本文将详细介绍如何使用PHP来读取Excel文件,并介绍一个方便易用的PHP类库。我们将探讨基本概念、类库的选择、类的使用方法以及示例代码。 首先,我们需要了解Excel文件的格式。早期版本的Excel(.xls)文件使用...

    好用的php操作excel类

    通常,这个文件会包含如何实例化读者对象,打开Excel文件,遍历工作表,以及获取和处理单元格数据的步骤。例如,它可能包含以下基本流程: 1. 包含`excel_reader2.php`库:`require_once 'excel_reader2.php';` 2. ...

    php根据excel模板导出excel并合并单元格

    在PHP开发中,有时我们需要处理数据的导出功能,特别是生成Excel文件,这对于数据分析、报告制作等场景非常有用。"php根据excel模板导出excel并合并单元格"这个主题涉及了如何利用PHP来读取Excel模板,填充数据,并...

    PHP生成、下载excel、zip压缩文件_excelphp图片_excel_zip_php_

    以PHPSpreadsheet为例,你可以通过以下步骤创建一个包含图片的Excel文件: 1. **安装PHPSpreadsheet**:通过Composer(PHP的依赖管理工具)添加`composer require phpoffice/phpspreadsheet`。 2. **创建工作簿和...

    php mysql excel 乱码终极处理

    ### PHP MySQL Excel 乱码终极处理 #### 一、乱码产生的根本原因 在进行PHP开发过程中,尤其是在处理Excel文件并将其数据导入MySQL数据库时,经常会遇到乱码问题。这主要是由于不同环节间的字符编码不统一所导致的...

    php读取excel实例

    本文将详细介绍如何使用PHP来读取Excel文件,通过一个简单的实例来展示其实现过程,这对于任何需要在PHP后端处理Excel数据的开发者来说都是十分有用的。 首先,我们要了解的是,PHP本身并不直接支持读取Excel文件,...

    php使用excel_class.php操作Excel文件

    8. **示例代码**:在博客中,作者可能提供了使用`excel_class.php`的示例代码,展示了如何打开文件、读取数据、写入数据、保存文件等步骤。 由于没有具体的内容可供参考,这里只能提供一般性的介绍。如果想要了解更...

    PHP 导出Excel (注:导出带图片的EXCEL也支持)

    9. **示例代码**:`demo.php`文件中应包含上述步骤的完整实现,你可以参考并修改以适应自己的需求。 通过这个教程,你应该能理解如何使用PHP和phpspreadsheet库来创建带有图片的Excel文件,并解决可能的乱码问题。...

    php,excel导入,读取

    这些代码可能包含了如何打开Excel文件,读取工作表,将数据转换为数组,以及如何处理这些数据的基本步骤。 例如,一个基本的流程可能如下: 1. **引入库**:通过`require_once 'path/to/Spreadsheet_Excel_Reader....

    php导入导出Excel

    1. **导出MySQL到Excel**:先通过SQL查询获取数据库中的数据,然后用PHP将数据写入Excel文件,过程类似于上述的导出步骤。 2. **导入Excel到MySQL**:上传Excel文件,读取数据,然后批量插入或更新数据库。注意处理...

    php读取excel文件

    【标题】:“php读取excel文件” 在PHP中读取Excel文件是一项常见的任务,...在实际应用中,可以根据具体需求进行调整,例如支持更广泛的Excel文件格式(如.xlsx),优化数据处理性能,或者增加数据验证和清洗步骤。

    php控制EXCEL录入数据

    首先,PHP可以通过各种库来实现对Excel文件的操作,例如`PHPExcel`,这是PHP处理Excel文档的一个强大库,支持多种文件格式,如`.xls`、`.xlsx`等。在提供的文件列表中,`PHPExcel.php`是这个库的核心文件,包含了...

    php读取excel的类库

    当我们需要处理Excel数据时,PHP提供了一些库来方便我们直接读取和操作Excel文件,而无需通过导入数据库这一中间步骤。这样的做法可以提高效率,减少资源消耗,尤其在处理大量数据时更为实用。 标题中的"php读取...

    基于PHP的excel插件支持7.4(操作Excel实现导入导出).zip

    导入Excel文件通常涉及以下步骤: 1. 使用PHPExcel加载Excel文件:通过`PHPExcel_IOFactory`类的`load()`方法,可以加载Excel文件到PHP内存中。 2. 遍历数据:使用`getActiveSheet()`获取活动工作表,然后通过`...

    php上传excel

    在本篇文章中,我们将探讨如何使用 PHP 生成 Excel 文件,并介绍相关的知识点。 一、PHP header() 函数 PHP 的 header() 函数是生成 Excel 文件的关键。header() 函数用于发送 HTTP 头信息,告知浏览器如何处理下...

    php 实现从mysql导出excel中

    这篇教程将详细介绍如何使用PHP实现从MySQL数据库导出数据到Excel文件。 首先,我们需要理解基本的流程。这个过程通常包括以下几个步骤: 1. **连接MySQL数据库**:使用PHP的`mysqli_connect`或`PDO`函数建立与...

    PHP 生成excel文件

    这篇博客“PHP生成excel文件”可能介绍了如何利用PHP创建和操作Excel文件,这对于数据分析、报表生成或用户下载功能非常有用。 生成Excel文件在PHP中最常见的库是PHPExcel和its newer version,叫做phpspreadsheet...

    php导入excel

    在PHP开发中,有时我们需要处理来自用户上传的Excel文件,例如收集数据、分析或存储到数据库。`php导入excel`这个主题就是关于如何在PHP环境中读取和处理Excel文件的知识点。下面将详细介绍如何实现这一功能,以及...

    生成excel文件到指定目录的函数php类库

    要使用PHPSpreadsheet库生成Excel文件并保存到特定目录,你需要按照以下步骤操作: 1. **安装库**:首先,通过Composer(PHP的依赖管理工具)安装PHPSpreadsheet。在命令行中运行: ``` composer require ...

Global site tag (gtag.js) - Google Analytics