既然有PHPExcel,那么肯定也会有PHPWord库,且都是phpoffice家的。看了下文档,最终决定使用模板的方式来导出数据,感觉也是最简单的一种方式了。

过程如下:

使用composer下载PHPWord到项目中

composer require phpoffice/phpword

可以看到,phpword的下载量还是挺高的

下载完后就可以开始制作我们的需求模板了,如下图所示,模板中使用${变量名}作为占位符,到时候用代码替换即可,${company_name}、${pic}等都是占位符

制作好模板就可以开始写代码了。

//导出word大致可以分为三步
//1.创建模板对象
$document = new TemplateProcessor('./template.docx');//2.插入数据
//插入文字
$document->setValue('company_name', 'XXX有限公司');//插入图片
$document->setImageValue('pic1', './img/gyy.jpeg');
$document->setImageValue('pic2', './img/zyt.jpeg');//插入文字
$document->setValue('organizationo', '123456');//3.保存文件
$document->saveAs('./target.docx');

导出效果如下:

可以看到默认导出都word的图片比较小,phpword支持自定义图片的大小,这里需要修改setImageValue方法的第二个参数,如果想自定义宽高就需要传入一个数组,格式如下

array("path" => xx, "width" => yy, "height" => zz)

path代表要插入图片的路径,width和height分别代表宽高

修改后的代码如下

//1.创建模板对象
$document = new TemplateProcessor('./template.docx');//2.插入数据
//插入文字
$document->setValue('company_name', 'XXX有限公司');//插入图片,宽200像素,高300像素
$picParam = ['path' => './img/gyy.jpeg', 'width' => 200, 'height' => 300];
$document->setImageValue('pic1', $picParam);$picParam2 = ['path' => './img/zyt.jpeg', 'width' => 200, 'height' => 300];
$document->setImageValue('pic2', $picParam2);//插入文字
$document->setValue('organizationo', '123456');//3.保存文件
$document->saveAs('./target.docx');

最终导出效果如下:

图片变成了我们期望的大小了。

如果想把生成的文件下载到浏览器,可以在生成文件后加上如下代码即可

//4.从浏览器下载
ob_clean();
ob_start();
$fp = fopen('./target.docx',"r");
$file_size = filesize('./target.docx');
Header("Content-type:application/octet-stream");
Header("Accept-Ranges:bytes");
Header("Accept-Length:".$file_size);
Header("Content-Disposition:attchment; filename=".'测试文件.docx');
$buffer = 1024;
$file_count = 0;
while (!feof($fp) && $file_count < $file_size){$file_con = fread($fp,$buffer);$file_count += $buffer;echo $file_con;
}
fclose($fp);
ob_end_flush();

以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家,需要

PHP进阶架构师>>>视频、面试文档免费获取​shimo.im

或 者关注咱们下面的知乎专栏

PHP架构师圈子​zhuanlan.zhihu.com

java导出word文档_PHPWord导出word文档相关推荐

  1. java freemarker 图片_java通过freemarker导出包含富文本图片的word文档

    废话不多说,进入正题! 本文重点在于:对富文本图片的导出(基础的freemarker+word模板导出这里不做详细解说哈) (ps:大神的东西太深奥~~懵逼了 一周才搞定,为了方便后来在更加简单,清晰 ...

  2. java freemarker word_Java 用Freemarker完美导出word文档(带图片)(示例代码)

    Java  用Freemarker完美导出word文档(带图片) 前言 最近在项目中,因客户要求,将页面内容(如合同协议)导出成word,在网上翻了好多,感觉太乱了,不过最后还是较好解决了这个问题. ...

  3. Java使用POI生成折线图导出到word文档(折线图)

    本篇文章主要介绍,如何使用Apache POI组件生成折线图导出到word文档中,具体步骤看下文. 一.实现效果 Java使用POI技术生成折线图导出到word文档中,最终生成的折线图如下所示: 二. ...

  4. 【操作word】Java + POI导出富文本的内容到word文档

    这周工作中,遇到一个需求是需要将数据库中富文本内容导出到word文档里面,于是就采用POI技术实现了一下导出word文档的功能.(word文档是识别html内容的,所以富文本内容也自然能够识别.) 一 ...

  5. java 导出word 带格式_java 导出数据为word文档(保持模板格式)

    导出数据到具体的word文档里面,word有一定的格式,需要保持不变 这里使用freemarker来实现: ①:设计好word文档格式,需要用数据填充的地方用便于识别的长字符串替换  如  aaaaa ...

  6. mysql数据库结构导出word_Windows导出MySQL数据库表结构到Word文档-DBExportDoc V1.0 For MySQL...

    必要条件: 1.Microsoft Office Word(我用WPS不行) 2.mysql-connector-odbc 3.会看文档 下载地址:关注微信公众号:八四七,回复5获取,压缩包中包含有具 ...

  7. php利用mht导出word,解析掌握PHP导出Word文档原理

    解析掌握PHP导出Word文档原理 PHP言语可能被咱们用来完成很多性能.比如在网站树立中,咱们常常会用到网页导出数据的情况.今天就为大家引见无关PHP导出Word文档的原理. 普通,有2种方法可能导 ...

  8. 一键导出PostgreSQL数据库表设计为word文档

    背景 项目开始时,数据库表设计是从概要设计到详细设计,再到数据库中的表结构,有一套完整的文档: 然而,随着项目的演进,需求的变更,导致数据库表结构发生了比较大的变化(加表,加字段,改类型等),对于大多 ...

  9. easypoi导出word表格_java如何导出word和wps文档

    使用场景:打开一个表单页面,导出word或wps文件,代码框架基于springboot+jpa 一.准备word模板 二.pom.xml文件中引入依赖 <dependency><gr ...

最新文章

  1. 《中国人工智能学会通讯》——1.42 理解情感
  2. 西农韦革宏组揭示甘草根系微生物群落分布及其与根内次级代谢产物之间的联系...
  3. 物联网技术概论的课程编号_课程 物联网应用实战 7月班仅剩3个席位
  4. html抽奖源码_开源FPGA开发板OpenICE 介绍及抽奖
  5. @cacheable 设置过期时间_缓存面试三连击——聊聊Redis过期策略?内存淘汰机制?再手写一个LRU 吧!...
  6. 什么90%的人,自学python都不能学会,原来问题出在这,赶紧看看!
  7. 专业工程师看过来~ | RDD、DataFrame和DataSet的细致区别
  8. springboot拦截异常信息发送邮件提醒
  9. 3dmax的贴图烘焙
  10. 测试手机端APP时,模拟网速慢的情况
  11. 线性代数及矩阵论(八)
  12. 标题EMC干货之共模干扰 转载
  13. 验证是否正确迁出CESM2
  14. 操作系统安全防护技术
  15. js判断浏览器是否打开了控制台
  16. 视联网将会给行业带来怎么样的发展
  17. 手机维修刷机专业论坛:天目通移动维修论坛
  18. js 通讯录(多音字)
  19. [考试反思]0909csp-s模拟测试41:反典
  20. 三星oneUI安装谷歌商店的方法

热门文章

  1. 市场占比 44%,IDC 最新报告:阿里云智能语音市场排名第一
  2. 国内首家,快手上线千万级QPS QUIC集群
  3. 腾讯广告计算提速25%,腾讯云星星海SA2云服务器提供助力
  4. 有了 Service Mesh,还需要 API 网关吗?
  5. 信号问题可根除,苹果新款 iPhone 将搭载高通基带?
  6. 何为量子计算机? | CSDN 博文精选
  7. 横扫阿里、滴滴、美团后,阿里程序媛整理出这份厚厚的面经!
  8. 5G 和 IoT 究竟意味着什么?
  9. 在 GitHub 上收获 6519 颗 Star 的 Python 面试题资源,到底有多牛?
  10. Android 危险!