寒窗轩,寒川的个人网络博客,记录互联网事,学习网络编程、分享工作经验、人生感悟,包括但不限于程序代码、数据库、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
随笔
热门文章
请不要奇怪,为什么最近博客的文章是几年前的内容
ubuntu24.04无法安装向日葵,提示依赖libgconf-2-4怎么办?
ubuntu24.04安装网易云音乐
Ubuntu22.04中用thunar替换默认文件管理器,提示无法启动“TerminalEmulator“的首选应用程序
python读取旧的Excel文件的数据到新的Excel表中
nginx+php如何EventStream流式数据传输
python读取文件夹下图片并生成pdf文件
使用python把word转成pdf
VB.net开发的word转pdf的小工具
文章推荐
免责声明
关于博主
开篇第一章
随机推荐
爱因斯坦发明电灯?!
从游戏到团结合作
博客备案通过
本博客的发展方向
如何清除IE浏览器输入框记录
MySQL数据库的concat()函数为什么返回空
mysql如何更新(删除)某列所有记录
留言
mysql命令导入导出.sql文件
网页编程之针对html源码的搜索引擎优化(SEO)建议
友情连接
春燕网络
谢润的博客