今天有人问了一个导出到Excel的问题,经典的导出代码想来大家也都知道,就是循环读数据,写成一个HTML,然后存为一个.xls文件。
可以参考我之前的一篇文章:GridView导出到Excel和开源图表工具
这种文件是可以在Excel程序里正常打开的,但如果使用这种文件作为数据源文件再进行导入,但我们使用下面的经典Excel导入Sql的代码时,就会出错。
SELECT * FROM OPENROWSET( 'Microsoft.Jet.OLEDB.4.0 ', 'Excel 5.0;Data =[Excel表.xsl文件的路径];HDR=YES;IMEX=1 ', Sheet1$')
原因是这个导出的文件仅仅是一个文本的HTML文件,而不是Excel 的原始(native)文件格式。
大家可以这样测试一下,到这里http://mattberseth2.com/demo/Default.aspx?Name=Export+GridView+to+Excel&Filter=All 下载导出的Excel,这是用记事本打开,是这样的:
如果用Excel打开再另存一下,就是这样的了:
为了确保导出的Excel在各种版本和情况都可以使用,可以考虑转换为Excel的原始(native)格式。这个需要使用OLE 。有一点示范的代码:
// Convert HTML file to Excel native format
OLE excel
excel = CREATE OLE
if excel.ConnectTo (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
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
继续阅读与本文标签相同的文章
下一篇 :
Zune-好事多磨
-
古灵精怪的python——地址,浅拷贝与身份运算符
2026-05-25栏目: 教程
-
Google PR 到4了
2026-05-25栏目: 教程
-
如何使用C#调用Java
2026-05-25栏目: 教程
-
帮你找到色彩-Photoshop LAB Color
2026-05-25栏目: 教程
-
如何使用命令行删除TFS客户端无用的Workspace
2026-05-25栏目: 教程


