phpword组件类库的一些基本用法
本文中的所使用的环境如下
php版本:php7.4
phpword版本:0.18.3
安装:
composer require phpoffice/phpword
1、使用模式一:
模板生成word
使用场景:适合有一套固定的world文档模板,只有几个关键的地方需要改变
使用方式:下面介绍几行代码就足够完成整个word的替换了,需要更多功能参考文档
示例代码如下:
//模板的路径,word的版本最好是docx,要不然可能会读取不了,根据自己的模板位置调整
$path = 'public/letters/templates/word/letter1.docx';
//生成word路径,根据自己的目录调整
$filePath= 'public/letters/word/letter1.docx';
//声明一个模板对象、读取模板
$templateProcessor = new \PhpOffice\PhpWord\TemplateProcessor($path);
//替换模板中的变量,对应word里的 ${test}
$test ="这是替换的内容";
$templateProcessor->setValue('test',$test);//传值
//生成新的word
$templateProcessor->saveAs($filePath);
2、使用模式二:
代码编写生成word文档:
使用场景:需要更加灵活的生成world文档
语法介绍:介绍一些常用的、需要的功能,多余的也不介绍了,来些直观的才是重要的,需要更多功能参考文档
示例代码如下:
//声明一个phpword对象
$phpWord = new \PhpOffice\PhpWord\PhpWord();
//声明一个页面,用来存放页面的内容,相当于一个容器
$section = $phpWord->addSection();
//添加一个段落文字
$section->addText('This is text');
//声明普通文字,不同段落文字,可以在后面追加文字
$textrun = $section->addTextRun();
//添加文字
$textrun->addText('This');
//再上面内容的后面追加文字
$textrun->addText('is');
//文字换行,参数可以控制换行的行数
$textrun->addTextBreak(1);
//段落文字换行,参数可以控制换行的行数
$section->addTextBreak(1);
//文字样式,可以指定许多样式,具体可以参考文档字体样式
$textrun->addText('测试',array('size'=>18,'bold'=>true,'name'=>'宋体'));
//可以定义一个数组传进去,本质都是一个数组
$fontStyle['size']=12;
$fontStyle['bold']=true;
$textrun->addText('测试',$fontStyle);
//向word文档中添加一张图片
$section->addImage('./test.png');
//生成word文档
$filePath= './test.docx';
$objWriter = \PhpOffice\PhpWord\IOFactory::createWriter($phpWord, 'Word2007');
$objWriter->save($filePath); //保存生成的word文档路径
PS备注:
Phpword虽然可以用代码生成word,但对于一些文字图片的定位操控起来非常麻烦,甚至无法控制
尽量使用模板,直接改动模板更加方便,只替换一些关键字就好
使用模板的时候要注意word格式要是docx,使用doc可能会报错
3、Phpword生成文档后,直接下载
$phpWord = new \PhpOffice\PhpWord\PhpWord();
$section = $phpWord->createSection();
//$section = $phpWord->addSection();
//使用createSection()方法或者使用addSection()方法 作用都是一样的
$section->addText('Hello World!');
$file = 'HelloWorld.docx'; //文件名
header("Content-Description: File Transfer");
header('Content-Disposition: attachment; filename="' . $file . '"');
header('Content-Type: application/vnd.openxmlformats-officedocument.wordprocessingml.document');
header('Content-Transfer-Encoding: binary');
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
header('Expires: 0');
$xmlWriter = \PhpOffice\PhpWord\IOFactory::createWriter($phpWord, 'Word2007');
$xmlWriter->save("php://output"); //这里不要改
4、尾声
官方文档地址:PHPWord官方文档
民间翻译PHPWord文档中文版:PHPWord文档中文版
PHPWord文档中文版github地址:https://github.com/yangweijie/PHPWord/