.NET 导出 Excel文件

.NET 导出 Excel文件,第1张

问题很简单,建立excel类,在using代码段加入3个引用

using

Excel

=

Microsoft.Office.Interop.Excel

using

System.Reflection

using

System.ComponentModel

然后在程序中

写如下代码

Excel.Application

xapp

=

new

Excel.Application()

xapp.Application.Workbooks.Add(true)

Excel.Worksheet

xsheet

=

xapp.Sheets[1]

xsheet.Cells[1,1]

=

"单元格内容"

string

filepath

=@"D:\XX.xls"//

文件路径及文件

xsheet.SaveAs(filepath)

xapp.Workbooks.Close()

xapp.Quit()

System.GC.Collect()

当要导出的 DataTable 数据量很大时(比如行数几十万的情况下), NPOI 内存占用非常高,这里研究一下性能更好的 excel 导出方式

内存占用不超过【260 MB】,耗时【30秒】,生成文件大小【48.1MB】

显然,在只考虑生成文件的情况下,应该选择使用 OpenXmlWriter 的方式

GitHub Page-LargeDataExportExcel

导入excel库。

把数据放到

datagridview中。

Response.Clear()//清除缓冲区流中所有内容的输出

Response.Buffer

=

true//获取和设置一个值,该值指出是否缓冲输出,并在完成处理整个响应之后将其发送

Response.Charset

=

"GB2312"//获取和设置输出流的http字符集

Response.AppendHeader("Content-Disposition",

"attachmentfilename

=

FileName.xls")//将http头添加到输出流

//如果设置成GB2312导出的将是乱码

Response.ContentEncoding

=

System.Text.Encoding.UTF7

Response.ContentType

=

"application/ms-excel"//设置输出文件类型为excel文件

System.IO.StringWriter

oStringWriter

=

new

StringWriter()//实现一个用于将信息写入字符串

TextWriter

该信息存储在基础StringBuilder

System.Web.UI.HtmlTextWriter

oHtmlTextWriter

=

new

HtmlTextWriter(oStringWriter)//将标记字符和文本写入到asp.net控件输出流

this.GV_WJ.RenderControl(oHtmlTextWriter)

Response.Output.Write(oStringWriter.ToString())

Response.Flush()//向客户端发送所有输出流

Response.End()//结束


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9901871.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存