1. 程式人生 > >PHP導出excel word的代碼

PHP導出excel word的代碼

url code output port bsp 下載 第三方 osi 由於

php導出為word原理

一般,有2種方法可以導出doc文檔,一種是使用com,並且作為php的一個擴展庫安裝到服務器上,然後創建一個com,調用它的方法。安裝過office的服務器可以調用一個叫word.application的com,可以生成word文檔,不過這種方式我不推薦,因為執行效率比較低(我測試了一下,在執行代碼的時候,服務器會真的去打開一個word客戶端)。理想的com應該是沒有界面的,在後臺進行數據轉換,這樣效果會比較好,但是這些擴展一般需要收費。

第2種方法,就是用PHP導出Word文檔內容直接寫入一個後綴為doc的文件中即可。使用這種方法不需要依賴第三方擴展,而且執行效率較高。

word本身的功能還是很強大的,它可以打開html格式的文件,並且能夠保留格式,即使後綴為doc,它也能識別正常打開。這就為我們提供了方便。但是有一個問題,html格式的文件中的圖片只有一個地址,真正的圖片是保存在其他地方的,也就是說,如果將HTML格式寫入doc中,那麽doc中將不能包含圖片。那我們如何創建包含圖片的doc文檔呢?我們可以使用和html很接近的mht格式。

mht格式和html很類似,只不過在mht格式中,外部鏈接進來的文件,比如圖片、Javascript、CSS會被base64進行編碼存儲。因此,單個mht文件就可以保存一個網頁中的所有資源,當然,相比html,它的尺寸也會比較大。

mht格式能被word識別嗎?我將一個網頁保存成mht,然後修改後綴名為doc,再用word打開,OK,word也可以識別mht文件,並且可以顯示圖片。

好了,既然doc可以識別mht,下面就是考慮如何將圖片放入mht了。由於html代碼中的圖片的地址都是寫在img標簽的src屬性中,因此,只要提取html代碼中的src屬性值,就可以獲得圖片地址。當然,有可能您獲取到的是相對路徑,沒關系,加上URL的前綴,改成絕對路徑就可以了。有了圖片地址,我們就可以通過file_get_content函數獲取到圖片文件的具體內容,然後調用base64_encode函數將文件內容編碼成base64編碼,最後插入到mht文件的合適位置即可。

最後,我們有兩種PHP導出Word文檔方法將文件發送給客戶端,一種是先在服務器端生成一個doc文檔,然後將這個doc文檔的地址記錄下來,最後,通過header("location:xx.doc");就可以讓客戶端下載這個doc。還有一種是直接發送html請求,修改HTML協議的header部分,將它的content-type設置為application/doc,將content-disposition設置為attachment,後面跟上文件名,發送完html協議以後,直接將文件內容發送給客戶端,也可以讓客戶端下載到這個doc文檔。

<?
Header("Content-type: application/octet-stream");
Header("Accept-Ranges: bytes");
Header("Content-type:application/vnd.ms-excel");
Header("Content-Disposition:attachment;filename=export_excel_gshjsl.xls");

$tx=‘表頭‘;
echo $tx."\n\n";
echo "編號"."\t";
echo "姓名"."\t";
echo "\n";

echo "=\"411481198507150666\""."\t";
echo "=\"0123456\""."\t"; //帶上引號方便字符串輸出。相當如設置單元格格式為文本。
echo "\n";
?>

順便把簡單導出word文檔的代碼貼到這裏:

<?php
header("Content-Type: application/msword");
header("Content-Disposition: attachment; filename=doc.doc");
header("Pragma: no-cache");
header("Expires: 0");

$output = ‘<table border="1" cellspacing="2" cellpadding="2" width="90%" align="center">‘;
$output .= ‘<tr bgcolor="#cccccc"><td align="center">圖片</td></tr>‘;
$output .= ‘<tr bgcolor="#f6f7fa"><td><span style="color:#FF0000;"><strong>下面是一張圖片</strong></span></td></tr>‘;
$output .= ‘<tr><td align="center"><img src="http://zi.csdn.net/48260_2.gif"></td></tr>‘;
$output .= ‘</table>‘;


echo $output;
?>

PHP導出excel word的代碼