寒窗轩,寒川的个人网络博客,记录互联网事,学习网络编程、分享工作经验、人生感悟,包括但不限于程序代码、数据库、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
随笔
热门文章
php用fsockopen()函数实现模拟提交表单。
php curl利用嘀咕、搜狐微博API发布微博
开个淘宝网店买充值卡
excel表格中页码从第n页开始
EMlog再次升级了
pdf、word、txt、excel等文档转flash(swf)软件—虚拟打印机FlashPaper
夏普sharp ar-2918 显示小人和小太阳灯一直亮清除方法
PHP 获取系统信息,PHP 获取服务器详细信息
windows xp win7双系统引导wubi安装ubuntu linux
摸死你个性签名集合
文章推荐
请不要奇怪,为什么最近博客的文章是几年前的内容
Win10更新后不显示文字
PHP实现远程下载,并显示实时下载进度
开篇第一章
随机推荐
动易系统的数据库连接出错,请检查Conn.asp文件中的数据库参数设置解决方案。
筹划个小插件
(转)中国人必须知道的柒拾陆个常识
洗衣
不合格的emlog插件开发者
最近比较忙。。。
.htaccess非伪静态url跳转到伪静态url再伪静态
记录一下这一伟大历史的开心时刻
搜索引擎优化(SEO)学习
html 5学习-video标签插入视频
友情连接
春燕网络