夜鹰教程网-程序员的加油站
 当前位置:文章中心 >> Asp.net专题(WCF/WPF/WF)
ASP.NET中导入和导出标准Excel文件
夜鹰教程网 来源:www.yyjcw.com 日期:2016-10-18 17:08:56
本文所演示的导入和导出方法并未使用Excel COM组件,而是使用原始的ASP.NET OleDb驱动程序,这使得ASP.NET应用程序即使部署在未安装Excel的服务器上也同样能支持导入和导出校准的Excel格式文件。

ASP.NET中导入和导出标准Excel文件

本文所演示的导入和导出方法并未使用Excel COM组件,而是使用原始的ASP.NET OleDb驱动程序,这使得ASP.NET应用程序即使部署在未安装Excel的服务器上也同样能支持导入和导出校准的Excel格式文件。

 

一、导出

网上有不少关于ASP.NET应用程序导出Excel文件的方法,大多都是设置Response对象的Content-Type为“application/ms-excel”后,以字符串形式输出数据供用户下载(可参考:http://blog.csdn.net/jilm168/archive/2007/11/06/1869118.aspx)。

虽说这种方式确实能实现导出Excel文件的目的,但其导出的Excel文件是不标准的。如果你用记事本打开使用此方式导出的文件会发现该文件是一个纯文本文件,这个倒是次要的,因为强大的Excel绝对有能力识别并显示这种“伪”Excel文件,但如果我们的应用程序要支持导入的话,那么这一文件就无法被程序正确识别了。

为了导出标准的Excel文件,我们可以首先准备好一个标准Excel文件做为导出模板,导出数据时先创建此模板的一个副本,使用OleDb驱动程序向副本中写入数据后,将此副本的二进制字节流输出至客户端供用户下载,最后再删除此副本。

如何制做一个Excel文件模板呢?你可以在安装有Excel的机器上新建一个“Microsoft Excel 工作表”,在工作表的第一行设置好需要的字段,然后选中整个表,点右键选择“设置单元格格式”,在“数字”标签的“分类”列表选择“文本”,点击“确定” 并保存文件。将单元格格式设置为“文本”主要是为了防止日后导入数据时某些数据格式无法被识别。

有了这个模板,我们就可以开始写代码导出数据了。本示例所使用模板文件位于站点根目录,名为“demo.xls”,共包含三个列:“ID”、“姓名”和“生日”。

excel_template

// 根据模板文件创建副本
string filePath = Server.MapPath("~/" + Guid.NewGuid().ToString() + ".xls");
File.Copy(Server.MapPath("~/demo.xls"), filePath);
// 使用OleDb驱动程序连接到副本
OleDbConnection conn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filePath + ";Extended Properties=Excel 8.0;");
using (conn)
{
conn.Open();
// 增加记录
OleDbCommand cmd = new OleDbCommand("INSERT INTO [Sheet1$]([ID], [姓名], [生日]) VALUES(@Id, @Name, @Birthday)", conn);
cmd.Parameters.AddWithValue("@Id", "1");
cmd.Parameters.AddWithValue("@Name", "Hsu Yencheng");
cmd.Parameters.AddWithValue("@Birthday", "1981-10-13");
cmd.ExecuteNonQuery();
}
// 输出副本的二进制字节流
Response.ContentType = "application/ms-excel";
Response.AppendHeader("Content-Disposition", "attachment;filename=info.xls");
Response.BinaryWrite(File.ReadAllBytes(filePath));
// 删除副本
Response.Flush();//这一步很关键如果没有 文件就不能下载和保存
File.Delete(filePath);

 

二、导入

相对于导出,导入部分的实现代码要简单的多:
string filePath = Server.MapPath("~/info.xls");
OleDbDataAdapter da = new OleDbDataAdapter(
"SELECT * FROM [Sheet1$]",
"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filePath + ";Extended Properties=Excel 8.0");
DataTable dt = new DataTable();
da.Fill(dt);
// 接下来你就可以对 dt 为所欲为了……
上面的代码中,我们导入了位于站点根目录的“info.xls”,导入时我们依旧使用OleDb驱动程序来访问Excel文件。再次提醒读者,此种方式只支持导入标准的Excel文件,这也是上面导出部分使用预先准备好的Excel模板文件的原因。

另外,以上演示仅针对Excel 2000-2003格式的文件,如果您要导入或导出的是Excel 2007文件(*.xlsx),那么您需要将连接字符串改为(可参考:http://www.connectionstrings.com/):
Provider=Microsoft.ACE.OLEDB.12.0;Data Source=info.xlsx;Extended Properties="Excel 12.0 Xml;HDR=YES";
Provider=Microsoft.ACE.OLEDB.12.0;Data Source=info.xlsx;Extended Properties="Excel 12.0 Xml;HDR=YES";

-----经过实践,上面的方法是可行,但有个问题:执行效率很低,超过255行的数据导出时,特别的慢(在网上查得是MS的限制).解决方法是:将INSERT部分不使用参数模式,而直接使用串拼接成INSERT的SQL语句,执行起来速度很快,导出时也很快,超过255时也很快,我仅测试过用SQL串语句生成并导出2000条,文件大小有3M,速度是不慢的,完成可以接受.而使用原方法,在256条时就感觉到慢了.

另外:OLEDB模式下可以先用CREATE TABLE生成SHEET1$这种EXCEL工作表,然后再INSERT数据,证实是可行的.这样模板文件就只要一个空白的EXCEL文档了.灵活性高很多.仍然要感谢原作者提供的方法.解决了我工作中的问题:)3Q

复制链接 网友评论 收藏本文 关闭此页
上一条: Asp.net 以二进制流实现上传和下载…  下一条: asp.net中导出Execl有两种方法
夜鹰教程网成立于2008年,目前已经运营了将近 13 年,发布了大量关于 html5/css3/C#/asp.net/java/python/nodejs/mongodb/sql server/android/javascript/mysql/mvc/easyui/vue/echarts原创教程。 我们一直都在坚持的是:认证负责、一丝不苟、以工匠的精神来打磨每一套教程,让读者感受到作者的用心。我们默默投入的时间,确保每一套教程都是一件作品,而不是呆板的文字和视频! 目前我们推出在线辅导班试运营,模式为一对一辅导,教学工具为QQ。我们的辅导学科包括 java 、android原生开发、webapp开发、商城开发、C#和asp.net开发,winform和物联网开发、web前端开发,但不仅限于此。 普通班针对的是国内学员,例如想打好基础的大学生、想转行的有志青年、想深入学习的程序员、想开发软件的初学者或者业余爱好者等。 就业办针对即将毕业上岗的大四学生,或者打算转行的初级开发工程师。 留学生班针对的是在欧美、加拿大、澳洲、日本、韩国、新加坡等地留学的中国学子,目的是让大家熟练地掌握编程技能,按时完成老师布置的作业,并能顺利地通过考试。 详细咨询QQ:1416759661   夜鹰教程网  基于角色的权限管理系统(c-s/b-s)。
  夜鹰教程网  基于nodejs的聊天室开发视频教程
  夜鹰教程网  Git分布式版本管理视频教程
  夜鹰教程网  MVC+EasyUI视频教程
  夜鹰教程网  在线考试系统视频教程
  夜鹰教程网  MongoDB视频教程。
  夜鹰教程网 Canvas视频教程
  夜鹰教程网 报表开发视频教程
  热点推荐
表单提交中get和post方式的区别有…
解决ASP中UTF-8与GB2312编码转换乱…
asp数组中REDIM的用法(动态数组)…
生成html的新方法ASP
ASP字符串函数大全
ASP生成Word文件的代码
ASP中Randomize随机函数的使用
十天学会ASP教程之第一天:安装调…
自定义的asp日期格式化函数
防范ASP网站漏洞的八大法则之一
十天学会ASP教程之第二天:表单传…
asp中关于从utf8页面到gb2312页面…
ASP教程:实现长文章分页功能
IIS6架设网站的问题总结
五分钟打开 allow_url_fopen 的最…
  最近更新
C# Json数据中的特殊字符导致页面…
博客园是有开发博客查询相关的接口…
C#里面的ref和out区别
C#调用API让声卡发出声音
.NET使用反射读取用户自定义的枚举…
.net操作SqlServer数据库增删改查…
如何将WCF服务部署到远程服务器
对WebApi 实现服务端信息的监控
用WCF生成Restful风格的接口返回 …
只有一个地址如何调用WCF服务
WCF简介
搭一个简单的wcf服务
WCF配置说明
WCF传输的数据量过大问题的解决方…
asp.net大文件分块上传文件秒传断…

关于我们 | 网站建设 | 技术辅导 | 常见问题 | 联系我们 | 友情链接

夜鹰教程网 版权所有 www.yyjcw.com All rights reserved 备案号:蜀ICP备08011740号3