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安装的插件的命名空间是什么?

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

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

插件自带代码实例

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

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

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

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

第十八行代码不需要

 <?php

// [ 应用入口文件 ]

 // 定义应用目录
 define('APP_PATH', __DIR__ . '/../application/');
// 加载框架引导文件
 require __DIR__ . '/../thinkphp/start.php';
 //require __DIR__ . '/../vendor/autoload.php';</pre>

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表的地方引入即可:

<?php

namespace app\index\controller;

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

class Office
{

    /**
     * 导出excel表
     * $data:要导出excel表的数据,接受一个二维数组
     * $name:excel表的表名
     * $head:excel表的表头,接受一个一维数组
     * $key:$data中对应表头的键的数组,接受一个一维数组
     * 备注:此函数缺点是,表头(对应列数)不能超过26;
     *循环不够灵活,一个单元格中不方便存放两个数据库字段的值
     */
    public function outdata($name='测试表', $data=[], $head=[], $keys=[])
    {
        $count = count($head);  //计算表头数量

        $spreadsheet = new Spreadsheet();
        $sheet = $spreadsheet->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已经帮我们做了,再引会造成一些方法重复定义)

这样直接就用了

<?php
  namespace app\admin\controller\test\phpspreadsheet;
  
  use app\admin\controller\Base; 
  use PhpOffice\PhpSpreadsheet\Spreadsheet; 7 use PhpOffice\PhpSpreadsheet\Writer\Xlsx; 8 
  class Index extends Base 
{ 
    public function index() 
{ 
      $spreadsheet = new Spreadsheet(); 
    $sheet = $spreadsheet->getActiveSheet(); 
        $sheet->setCellValue('A1', 'Hello World !'); 
         $writer = new Xlsx($spreadsheet); 
         $writer->save('d://hello world.xlsx'); 
         //dump('2222222222');die; 
         //return view();
 } 
 }

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

第十八行代码不需要

 <?php
 // | ThinkPHP [ WE CAN DO IT JUST THINK ]
// +----------------------------------------------------------------------
 // | Copyright (c) 2006-2016 http://thinkphp.cn All rights reserved.
 // +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: liu21st <liu21st@gmail.com>
 // +---------------------------------------------------------------------- 
 
// [ 应用入口文件 ] 
 // 定义应用目录
define('APP_PATH', __DIR__ . '/../application/'); 
 // 加载框架引导文件
 require __DIR__ . '/../thinkphp/start.php'; 
//require __DIR__ . '/../vendor/autoload.php';

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,590评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,808评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,151评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,779评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,773评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,656评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,022评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,678评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,038评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,756评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,411评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,005评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,973评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,053评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,495评论 2 343

推荐阅读更多精彩内容

  • 是什么 如果你知道yum、apt-get、npm、bower等命令中的一种或者多种,那么,你也能很快知道compo...
    旱魃一样阅读 3,113评论 0 9
  • 首先到phpexcel官网上下载最新的phpexcel类,下周解压缩一个classes文件夹,里面包含了PHPEx...
    gongji阅读 6,573评论 0 3
  • 当系统有不同的web应用,但是需要共用很多代码怎么办当系统需要一个扩展功能而这个扩展功能网上刚好有人提供了怎么用P...
    fmw阅读 3,822评论 7 40
  • Composer 的结构 Root Package(根目录包) 根目录包就是在你的项目的根目录由 composer...
    独步弈城阅读 3,741评论 0 1
  • Composer是一个非常流行的PHP包依赖管理工具,已经取代PEAR包管理器,对于PHP开发者来说掌握Compo...
    bycall阅读 2,164评论 0 1