PHPExcel表格处理phpSpreadsheet的简单使用

[PhpSpreadsheet的简单使用]

由于PHPExcel已经不再维护,PhpSpreadsheet是PHPExcel的下一个版本。PhpSpreadsheet是一个用纯PHP编写的库,并引入了命名空间,PSR规范等。这里简单介绍下PhpSpreadsheet的导入导出功能。

1、安装

  • 使用composer安装:
composer require phpoffice/phpspreadsheet

GitHub下载:

https://github.com/PHPOffice/PhpSpreadsheet

2、excel文件导出

/**
 * excel文件导出
 */
function export()
{
    require_once __DIR__ . '/vendor/autoload.php';
 
    $data = [
        ['title1' => '111', 'title2' => '222'],
        ['title1' => '111', 'title2' => '222'],
        ['title1' => '111', 'title2' => '222']
    ];
    $title = ['第一行标题', '第二行标题'];
 
    // Create new Spreadsheet object
    $spreadsheet = new \PhpOffice\PhpSpreadsheet\Spreadsheet();
    $sheet = $spreadsheet->getActiveSheet();
 
    // 方法一,使用 setCellValueByColumnAndRow
    //表头
    //设置单元格内容
    foreach ($title as $key => $value) {
        // 单元格内容写入
        $sheet->setCellValueByColumnAndRow($key + 1, 1, $value);
    }
    $row = 2; // 从第二行开始
    foreach ($data as $item) {
        $column = 1;
        foreach ($item as $value) {
            // 单元格内容写入
            $sheet->setCellValueByColumnAndRow($column, $row, $value);
            $column++;
        }
        $row++;
    }
 
    // 方法二,使用 setCellValue
    //表头
    //设置单元格内容
    $titCol = 'A';
    foreach ($title as $key => $value) {
        // 单元格内容写入
        $sheet->setCellValue($titCol . '1', $value);
        $titCol++;
    }
    $row = 2; // 从第二行开始
    foreach ($data as $item) {
        $dataCol = 'A';
        foreach ($item as $value) {
            // 单元格内容写入
            $sheet->setCellValue($dataCol . $row, $value);
            $dataCol++;
        }
        $row++;
    }
 
    // Redirect output to a client’s web browser (Xlsx)
    header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
    header('Content-Disposition: attachment;filename="01simple.xlsx"');
    header('Cache-Control: max-age=0');
    // If you're serving to IE 9, then the following may be needed
    header('Cache-Control: max-age=1');
 
    // If you're serving to IE over SSL, then the following may be needed
    header('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past
    header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); // always modified
    header('Cache-Control: cache, must-revalidate'); // HTTP/1.1
    header('Pragma: public'); // HTTP/1.0
 
    $writer = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($spreadsheet, 'Xlsx');
    $writer->save('php://output');
    exit;
}

结果:

image

3、excel文件保存到本地

/**
 * excel文件保存到本地
 */
function save()
{
    require_once __DIR__ . '/vendor/autoload.php';
 
    $data = [
        ['title1' => '111', 'title2' => '222'],
        ['title1' => '111', 'title2' => '222'],
        ['title1' => '111', 'title2' => '222']
    ];
    $title = ['第一行标题', '第二行标题'];
 
    // Create new Spreadsheet object
    $spreadsheet = new \PhpOffice\PhpSpreadsheet\Spreadsheet();
    $sheet = $spreadsheet->getActiveSheet();
 
    //表头
    //设置单元格内容
    $titCol = 'A';
    foreach ($title as $key => $value) {
        // 单元格内容写入
        $sheet->setCellValue($titCol . '1', $value);
        $titCol++;
    }
    $row = 2; // 从第二行开始
    foreach ($data as $item) {
        $dataCol = 'A';
        foreach ($item as $value) {
            // 单元格内容写入
            $sheet->setCellValue($dataCol . $row, $value);
            $dataCol++;
        }
        $row++;
    }
 
    // Save
    $writer = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($spreadsheet, 'Xlsx');
    $writer->save('01simple.xlsx');
}

4、读取excel文件内容

/**
 * 读取excel文件内容
 */
function read()
{
    require_once __DIR__ . '/vendor/autoload.php';
    $inputFileName = dirname(__FILE__) . '/01simple.xlsx';
    $spreadsheet = \PhpOffice\PhpSpreadsheet\IOFactory::load($inputFileName);
    // 方法二
    $sheetData = $spreadsheet->getActiveSheet()->toArray(null, true, true, true);
    return $sheetData;
}

结果:

image

可能出现的问题:

1、Fatal error: Uncaught Error: Class 'PhpOffice\PhpSpreadsheet\Spreadsheet' not found

这是因为没有自动加载。可以手动引入加载文件。

require_once __DIR__ . '/vendor/autoload.php';

或者:

require_once __DIR__ . '/vendor/phpoffice/phpspreadsheet/src/Bootstrap.php';

2、Fatal error: Interface 'Psr\SimpleCache\CacheInterface' not found

这是因为没有psr文件,缺少simple-cache模块。如果使用composer安装的话会自动生成。没有的话可以手动下载。

GitHub下载地址:https://github.com/php-fig/simple-cache/releases

目录

  • 一、总结
    • 一句话总结:多百度,百度什么都有
    • 1、thinkphp中用composer安装的插件的命名空间是什么?
    • 2、插件的代码实例哪里找?
    • 3、在thinkphp中安装好了插件,我们需要在入口文件中require包么?
    • 4、我们要调用自己安装的插件的类,use的格式是怎样的?
  • 二、TP5使用Composer安装PhpSpreadsheet类库实现导出Excel表并封装
  • 三、TP5,用composer加载了phpSpreadSheet后怎么用呢?
  • 四、自己测试实例(亲测通过)
  • Installation

回到顶部

> 一、总结(点击显示或隐藏总结内容)

一句话总结:多百度,百度什么都有

1、thinkphp中用composer安装的插件的命名空间是什么?

use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;

2、插件的代码实例哪里找?

插件自带代码实例

\vendor\phpoffice\phpspreadsheet\samples\里面有例程,仔细看下

3、在thinkphp中安装好了插件,我们需要在入口文件中require包么?

不需要,thinkphp已经给我们做了

注意:不需要自己在入口文件中再require包了

第十八行代码不需要

 

4、我们要调用自己安装的插件的类,use的格式是怎样的?

其实use就是永远和文件的命名空间是相对应的

直接看需要文件定义的命名空间:比如说下面第一个文件Spreadsheet的命名空间就是这个:namespace PhpOffice\PhpSpreadsheet;
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;

二、TP5使用Composer安装PhpSpreadsheet类库实现导出Excel表并封装

一、背景介绍:

PhpSpreadsheet是PHPExcel的下一个版本。它打破了兼容性,大大提高了代码库质量(命名空间,PSR合规性,最新PHP语言功能的使用等)。

由于所有努力都转移到了PhpSpreadsheet,因此将不再维护PHPExcel。PHPExcel,补丁和新功能的所有贡献都应该针对PhpSpreadsheet开发分支。

前提:TP5项目中已经安装配置好*Composer *管理工具包。

二、Composer 中文网 / Packagist 中国全量镜像:https://www.phpcomposer.com/ 打开安装包列表搜索phpspreadsheet;

资源链接:https://packagist.org/packages/phpoffice/phpspreadsheet 复制命令composer require phpoffice/phpspreadsheet,

在开发工具(比如:PHPSTORM)命令行(terminal)中执行;

三、创建Office类文件并封装,在需要导出Excel表的地方引入即可:

getActiveSheet();

        for ($i = 65; $i < $count + 65; $i++) {     //数字转字母从65开始,循环设置表头:
            $sheet->setCellValue(strtoupper(chr($i)) . '1', $head[$i - 65]);
        }

        /*--------------开始从数据库提取信息插入Excel表中------------------*/

        foreach ($data as $key => $item) {             //循环设置单元格:
            //$key+2,因为第一行是表头,所以写到表格时   从第二行开始写

            for ($i = 65; $i < $count + 65; $i++) {     //数字转字母从65开始:
                $sheet->setCellValue(strtoupper(chr($i)) . ($key + 2), $item[$keys[$i - 65]]);
                $spreadsheet->getActiveSheet()->getColumnDimension(strtoupper(chr($i)))->setWidth(20); //固定列宽
            }

        }

        header('Content-Type: application/vnd.ms-excel');
        header('Content-Disposition: attachment;filename="' . $name . '.xlsx"');
        header('Cache-Control: max-age=0');
        $writer = new Xlsx($spreadsheet);
        $writer->save('php://output');

        //删除清空:
        $spreadsheet->disconnectWorksheets();
        unset($spreadsheet);
        exit;
    }

调用示例:


$excel = new Office();

//设置表头:
 $head = ['订单编号', '商品总数', '收货人', '联系电话', '收货地址'];

//数据中对应的字段,用于读取相应数据:
$keys = ['order_sn', 'num', 'consignee', 'phone', 'detail'];            

$excel->outdata('订单表', $orders, $head, $keys);

参考:TP5使用Composer安装PhpSpreadsheet类库实现导出Excel表并封装 - 逍逍逍遥虎的博客 - CSDN博客
https://blog.csdn.net/qq_41962562/article/details/82315608

回到顶部

三、TP5,用composer加载了phpSpreadSheet后怎么用呢?

\vendor\phpoffice\phpspreadsheet\samples\里面有例程,仔细看下

use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;

use PhpOffice\PhpSpreadsheet\IOFactory;
$path = ROOT_PATH . "public/" . $filename;
setlocale(LC_ALL, 'zh_CN');  //csv中文乱码
 $inputFileType = IOFactory::identify($path);
 $excelReader = IOFactory::createReader($inputFileType);
if ($inputFileType == 'Csv') {   //csv文件读取设置
  $excelReader->setInputEncoding('GBK');
   $excelReader->setDelimiter(',');
 } 
$phpexcel = $excelReader->load($path); 11 $activeSheet = $phpexcel->getActiveSheet(); 12 $sheet = $activeSheet->toArray();

上面一个是读取,写出的代码就不贴了,找下phpexcel的改下命名空间就差不多了,

 use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\IOFactory; 

四、自己测试实例(亲测通过)

比如我们现在在thinkphp5中要用phpspreadsheet插件

第一步:找到插件官网的composer安装方法

Installation

Use [composer](https://getcomposer.org/) to install PhpSpreadsheet into your project:

composer require phpoffice/phpspreadsheet

Note: If you want the unreleased, unstable development version use phpoffice/phpspreadsheet:dev-develop instead.

第二步:在我们tp5系统的更目录下打开cmd命令行,运行这句话(要先在电脑上面装composer)

第三步:直接use包运行实例,不需要引(require)包(thinkphp已经帮我们做了,再引会造成一些方法重复定义)

这样直接就用了

getActiveSheet(); 
        $sheet->setCellValue('A1', 'Hello World !'); 
         $writer = new Xlsx($spreadsheet); 
         $writer->save('d://hello world.xlsx'); 
         //dump('2222222222');die; 
         //return view();
 } 
 }

注意:不需要自己在入口文件中再require包了

第十八行代码不需要

 
 // +---------------------------------------------------------------------- 
 
// [ 应用入口文件 ] 
 // 定义应用目录
define('APP_PATH', __DIR__ . '/../application/'); 
 // 加载框架引导文件
 require __DIR__ . '/../thinkphp/start.php'; 
//require __DIR__ . '/../vendor/autoload.php';

你可能感兴趣的:(PHPExcel表格处理phpSpreadsheet的简单使用)