PHP使用phpword生成word文檔

寫在前邊的話

使用phpword生成文檔有兩種方式

  • 直接使用代碼編寫word文檔,用代碼生成word,但是設置樣式,格式,圖片非常麻煩,不建議使用。如果客戶或產(chǎn)品提供一份word的樣式,我們也難以完全復原,調樣式很頭疼的。
  • 讀取原有word模板,替換相關變量。個人感覺這種方式能滿足絕大部分需求,實現(xiàn)起來也比較簡單,所有的樣式,格式直接在word模板里設置好,替換變量就可以了,還可以很方便的切換模板。本文主要介紹這種方式,畢竟我們是為了快速實現(xiàn)客戶的需求,讓客戶提供一份word模板,我們稍微一改就可以了。

開始干活

1,通過composer安裝phpword包

composer require phpoffice/phpword

2,準備一個word模板(讓客戶或產(chǎn)品提供吧,docx格式的)

先來一個簡單的


1.png

這是一個word文檔,我們首先要替換的是姓名,電話?,F(xiàn)在把這兩個值用變量代替,模板里面的變量樣式為 ${name} ,如下:

2.png

好了,一個簡單的模板可以了,就類似于html靜態(tài)頁面

3,開始替換變量(渲染模板)
include_once "vendor/autoload.php";
$tmp=new \PhpOffice\PhpWord\TemplateProcessor('tmp.docx');//打開模板
$tmp->setValue('name','李四');//替換變量name
$tmp->setValue('mobile','18888888888');//替換變量mobile
$tmp->saveAs('簡歷.docx');//另存為

打開 簡歷.docx 可以看到變量已經(jīng)被替換了

3.png

OK,流程就是這樣,是不是突然覺得導出word很簡單?


下面開始一些進階的功能
如果遇到表格樣式的,但又不確定是多少行,如下,教育經(jīng)歷的行數(shù)是不確定的


4.png

這需要用的克隆行,模板修改如下


5.png

這里要記住的是表格左上角的變量school,這個變量用來控制你要復制的是哪一行,復制以后會生成類似于school#1,year#1,school#2,year#2,school#3,year#3 這樣的變量
渲染模板

//2復制行
$arr=[
    ['school'=>'大學','year'=>'2014'],
    ['school'=>'大學','year'=>'2014'],
    ['school'=>'大學','year'=>'2014'],
    ['school'=>'大學','year'=>'2014'],
    ['school'=>'大學','year'=>'2014'],
    ['school'=>'大學','year'=>'2014'],
    ['school'=>'大學','year'=>'2014'],
];
$rows=count($arr);//總行數(shù)
$tmp->cloneRow('school',$rows);//復制行
for($i=0;$i<$rows;$i++){
    $tmp->setValue("school#".($i+1),$arr[$i]['school']);//替換變量
    $tmp->setValue("year#".($i+1),$arr[$i]['year']);
}

結果:


5.png

上面是行clone,有時候我們可能要用到塊clone,如下面這種情況,如果有獲獎記錄,我希望顯示這一塊,如果沒有,就整個不顯示


6.png

這時我們就要加一個塊標簽了,與html標簽格式類似,成對出現(xiàn),如下圖


7.png

下面來渲染,當winning有值是顯示win_block模塊,并渲染winning_record,沒有值是不顯示win_block模塊
$winning_record="";
if($winning_record != ''){
    $tmp->cloneBlock('WIN_BLOCK',1);
    $tmp->setValue('winning_record',$winning_record);
}else{
    #$tmp->deleteBlock('WIN_BLOCK');//這個方法會出錯,原因不知,用cloneBlock來代替
    $tmp->cloneBlock('WIN_BLOCK',0);
}

結果就不展示了,自己測試一下就可以了,這里的deleteBlock方法不能用,原因我也不知道,我就用cloneBlock復制0行來代替了


替換圖片

img1.png

直接把圖片換成變量


2.png

渲染

$tmp->setImageValue('header',['path'=>'1.jpeg']);
設置圖片寬高
$tmp->setImageValue('header', ['path' => '1.jpg','width'=>500,'height'=>500]);
設置多次替換
$tmp->setImageValue('header', ['path' => '1.jpg','width'=>500,'height'=>500],3);

一些常用的word符號

換行符 <w:br/>
分頁符 <w:br w:type="page"/>
制表符 <w:tab/>
html預留字符要替換為實體字符,如&要替換為&amp;,可以使用htmlspecialchars()
使用方式
比如我們數(shù)據(jù)庫存的換行符一般是 \n\r 這個在word中是無效的,要替換為 <w:br/> 才行

$content = str_replace("\r\n", '<w:br />', $content);
$tem->setValue('content', $content); //內容

本文PHP測試代碼gitee
如果有問題,可以留言一起研究學習

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

友情鏈接更多精彩內容