寒窗轩,寒川的个人网络博客,记录互联网事,学习网络编程、分享工作经验、人生感悟,包括但不限于程序代码、数据库、Office办公、随笔等内容。

PHP以Excel模板填充数据并生成新的Excel文件

遇到这个一个问题,需要生成带水印的Excel文件,具体思路如下:先设置一个调好格式的Excel文件作为模板,再用PHP以模板文件填充,并生成新的Excel文件,这样新的文件就和模板文件格式一致。程序用到了PhpSpreadsheet,步骤如下:

1、下载PhpSpreadsheet扩展,命令:

composer require phpoffice/phpspreadsheet

至于怎么安装composer,以及怎么设置国内镜像等问题本文不着讨论。

2、phpspreadsheet安装完成后就直接上代码:

<?php
require 'vendor/autoload.php';

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

//指定模板文件所在位置
$template = 'template.xlsx';

$spreadsheet = \PhpOffice\PhpSpreadsheet\IOFactory::load($template);

//将活动工作表索引设置为第一个工作表:
$spreadsheet->setActiveSheetIndex(0);
//获取活动工作表
$worksheet = $spreadsheet->getActiveSheet();
//填充数据
$worksheet->getCell('A2')->setValue('1');
$worksheet->getCell('B2')->setValue('张三');
$worksheet->getCell('C2')->setValue('项目');
$worksheet->getCell('D2')->setValue('项目');
$worksheet->getCell('E2')->setValue('项目');
$worksheet->getCell('F2')->setValue('项目');
//继续填充数据
$worksheet->getCell('A3')->setValue('2');
$worksheet->getCell('B3')->setValue('李四');
$worksheet->getCell('C3')->setValue('项目');
$worksheet->getCell('D3')->setValue('项目');
$worksheet->getCell('E3')->setValue('项目');
$worksheet->getCell('F3')->setValue('项目');
//将填充好数据的工作表保存
$writer = new Xlsx($spreadsheet);
$writer->save('newfile.xlsx');

程序运行截图如下:

模板文件效果

模板文件效果

生成的文件效果

生成的文件效果

昵称:

验证码:验证码

评论:

文章分类
系统
程序
数据
Office
随笔
热门文章
Excel文件内容很少,但文件很大,打开很慢、很卡怎么办?
PHP实现远程下载,并显示实时下载进度
2020开局不顺
Excel如何批量替换字符串?讲解Excel的字符替换函数SUBSTITUTE
CentOS无法删除文件怎么办
本博客系统开启评论IP黑名单、关键词黑名单功能
超酷绚的Excel点选变色,自动求合功能
开篇第一章
饥饿站台观后感
PHP以Excel模板填充数据并生成新的Excel文件
文章推荐
Win10更新后不显示文字
PHP实现远程下载,并显示实时下载进度
开篇第一章
随机推荐
2020开局不顺
Excel文件内容很少,但文件很大,打开很慢、很卡怎么办?
PHP7报错:Call to undefined function mysql_connect(),如何兼容mysql_connect函数
写在母亲忌日
Excel如何批量替换字符串?讲解Excel的字符替换函数SUBSTITUTE
饥饿站台观后感
超酷绚的Excel点选变色,自动求合功能
PHP实现远程下载,并显示实时下载进度
win10切换虚拟桌面
CentOS无法删除文件怎么办
友情连接
春燕网络