天天看點

GridView導出為Excel後,導出的.xls檔案無法作為源檔案導入的問題

今天有人問了一個導出到Excel的問題,經典的導出代碼想來大家也都知道,就是循環讀資料,寫成一個HTML,然後存為一個.xls檔案。

可以參考我之前的一篇文章:

GridView導出到Excel和開源圖表工具 這種檔案是可以在Excel程式裡正常打開的,但如果使用這種檔案作為資料源檔案再進行導入,但我們使用下面的經典Excel導入Sql的代碼時,就會出錯。

SELECT * FROM   OPENROWSET( 'Microsoft.Jet.OLEDB.4.0 ', 'Excel   5.0;DatabASE=[Excel表.xsl檔案的路徑];HDR=YES;IMEX=1 ', Sheet1$')      

原因是這個導出的檔案僅僅是一個文本的HTML檔案,而不是Excel 的原始(native)檔案格式。

大家可以這樣測試一下,到這裡

http://mattberseth2.com/demo/Default.aspx?Name=Export+GridView+to+Excel&Filter=All

下載下傳導出的Excel,這是用記事本打開,是這樣的:

GridView導出為Excel後,導出的.xls檔案無法作為源檔案導入的問題

如果用Excel打開再另存一下,就是這樣的了:

GridView導出為Excel後,導出的.xls檔案無法作為源檔案導入的問題

為了確定導出的Excel在各種版本和情況都可以使用,可以考慮轉換為Excel的原始(native)格式。這個需要使用OLEObject。有一點示範的代碼:

//     Convert     HTML     file     to     Excel     native     format      

OLEObject     excel      

excel     =     CREATE     OLEObject      
if     excel.ConnectToObject(docname)     =     0     then      

excel.application.DisplayAlerts     =     FALSE      

excel.application.workbooks(1).Parent.Windows(excel.application.workbooks(1).Name).Visible     =     True      

excel.application.workbooks(1).saveas(docname,     39)      

excel.application.workbooks(1).close()      

end     if      


DESTROY     excel      
//     done         
Excel表資料導入Sql Server資料庫中 Export to Excel :Use ASP.NET to send functionally rich reports to your users. How To Export Data in a DataGrid on an ASP . NET WebForm to Microsoft Excel 一個有關儲存為EXCEL的問題.馬上給分!