PHP匯出excel word的代碼

來源:互聯網
上載者:User

標籤:net   src   com   也會   絕對路徑   location   ext   encode   chm   

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的代碼

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.