欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【ASP.NET用DataSet导出到Excel的方法】,下面是详细的讲解!
ASP.NET用DataSet导出到Excel的方法
/读取临时文件
GYYW.DA.Common.Base_SqlDataBase daBZDM=new GYYW.DA.Common.Base_SqlDataBase();
DataSet dsBZDM=daBZDM.GetDataSetBySql("select QCDM,MC,GG from WG_BZDM where QCDM like '02%'");
//同时将虚拟目录下的Data作为临时文件目录。
string urlPath=HttpContext.Current.Request.ApplicationPath + "/Data/";
string physicPath=HttpContext.Current.Server.MapPath(urlPath);
//string fileName=Guid.NewGuid() + ".Xls";
string fileName="DownLoad.Xls";
string connString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + physicPath + fileName +";Extended Properties=Excel 8.0;";
OleDbConnection objConn=new OleDbConnection(connString);
OleDbCommand objCmd=new OleDbCommand();
objCmd.Connection=objConn;
objCmd.Connection.Open();
//建立表结构
objCmd.CommandText=@"CREATE TABLE Sheet1(器材代码 varchar,名称 varchar, 规格 varchar)";
objCmd.ExecuteNonQuery();
//建立插入动作的Command
objCmd.CommandText="INSERT INTO Sheet1(器材代码, 名称,规格) VALUES (@QCDM, @MC, @GG)";
objCmd.Parameters.Clear();
objCmd.Parameters.Add(new OleDbParameter("@QCDM", OleDbType.VarChar));
objCmd.Parameters.Add(new OleDbParameter("@MC", OleDbType.VarChar));
objCmd.Parameters.Add(new OleDbParameter("@GG",OleDbType.VarChar));
//遍历DataSet将数据插入新建的Excel文件中
foreach (DataRow row in dsBZDM.Tables[0].Rows)
{
for (int i=0; i<objCmd.Parameters.Count; i++)
{
objCmd.Parameters[i].Value=row[i];
}
objCmd.ExecuteNonQuery();
}
objCmd.Connection.Close();
//提供下载
//清除临时文件
HttpResponse response=HttpContext.Current.Response;
response.Clear();
//为输出作准备
response.WriteFile(urlPath + fileName);
string httpHeader="attachment;filename=KCMX.Xls";
response.AppendHeader("Content-Disposition", httpHeader);
response.Flush();
//输出完毕后清除临时文件
string strSaveDir="../Data/";
string strFile=Server.MapPath(strSaveDir + fileName).ToString();
//string sss=urlPath + fileName;
System.IO.File.Delete(strFile);//删除临时文件
response.End();
关于ASP.NET用DataSet导出到Excel的方法的用户互动如下:
相关问题:
答: >>详细
相关问题:
答: >>详细
相关问题:
答: >>详细
- 【asp】asp.net url重写浅谈-net-url重写
- 【DataSet】DataSet、DataTable、DataRow区别详解
- 【asp】asp.net 动态添加多个用户控件-net-动态添
- 【ASP】ASP.NET中内嵌页面代码的一个问题-NET-内
- 【As】Asp.net中的页面乱码的问题-sp--pn-ne-et
- 【增加记录】asp.net中获取新增加记录的ID Access
- 【创建】ASP.NET Web API教程 创建域模型的方法详
- 【Asp】Asp.net 页面调用javascript变量的值-net-
- 【ASP】ASP.NET 5升级后如何删除旧版本的DNX-NET5
- 【404页面】ASP.NET设置404页面返回302HTTP状态码
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
