1. 程式人生 > >web匯出excel檔案的幾種方法

web匯出excel檔案的幾種方法

 

總的來說,兩種方法:伺服器端生成和瀏覽器端生成。

伺服器端生成就是:根據使用者請求,獲取相應的資料,使用poi/jxl, jacob/jawin+excel,或是用資料拼html的table或是cvs純文字的資料格式等。然後按.xls或是.cvs格式的檔案的形式返回給使用者,指定Content-Type:application/vnd.ms-excel ,瀏覽器就會提示要下載的檔案是excel檔案。

poi/jxl, jacob/jawin生成的是excel的biff格式。html/csv的是文字格式,不另存為excel檔案,很多excel功能是用不了的。jacob/jawin需要伺服器端是windows系統,且安裝了excel2000以上版本。poi/jxl和html/csv方式的話,伺服器端可以跨平臺。

瀏覽器端生成excel檔案還沒有特別完善的方案,這是因為js無法處理二進位制。大概有以下幾個方案,各有利弊。

1. activex方式:使用js/vbs呼叫excel物件,http://setting.iteye.com/blog/219302,有個extjs的gridpanel匯出為excel的例子。 (ie+excel)

2. ie命令方式:將html或是csv輸出到open的window,然後使用execCommand的saveas命令,存為csv或xls。 (ie6 only)

3. 伺服器端中轉方式:將html的table或是拼接的csv傳到伺服器端,伺服器端再按照Content-Type:application/vnd.ms-excel返回,瀏覽器就會按excel方式處理。與伺服器端拼接相比,少了一次取數操作。 (all)

4. data協議方式:對於支援data協議的瀏覽器,可以將html或是csv先用js base64處理,然後字首data:application/vnd.ms-excel;base64,,即可使瀏覽器將其中的資料當做excel來處理,瀏覽器將提示下載或開啟excel檔案,可惜的是ie不支援。extjs的官網有一個grid的plugin,實現匯出xhtml格式的偽excel檔案,就是這麼做的。 (except IE)

瀏覽器端只有第一種方案匯出的是真正的biff格式的excel檔案,其他方式都是文字格式。activex方式只能在windows平臺的ie瀏覽器使用,而且需要降低ie的安全性,所以應用比較有限。複雜的excel檔案,還是在伺服器端用poi/jxl生成excel比較好。如果瀏覽器固定位ie6,瀏覽器端方式2是最好的方案。如果要降低伺服器端cpu的計算壓力,客戶端方案3可行,而且跨平臺(比poi/jxl方式少了取數和生成二進位制檔案)。如果是非ie瀏覽器,方案4也不失為一種好方法。

ps: 還有一個方案,就是讓安裝了ie和excel的使用者在網頁上右鍵,點選“匯出到 Microsoft Excel”,然後可以選擇要匯出的table區域,點“匯入”按鈕,完成匯入。