protected void ExpExcel(DataTable dt)
{
HttpContext.Current.Response.Clear();
HttpContext.Current.Response.ClearContent();
HttpContext.Current.Response.ClearHeaders();
HttpContext.Current.Response.Buffer = true; //仅仅是页面缓存
HttpContext.Current.Response.Charset = "GB2312";
HttpContext.Current.Response.AppendHeader("Content-Disposition", "attachment;filename=" + DateTime.Now.ToString("yyyyMMddHHmmss") + ".xls");
HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");//("GB2312");//设置输出流为简体中文
HttpContext.Current.Response.ContentType = "application/vnd.ms-excel";//设置输出文件类型为excel文件。
System.Globalization.CultureInfo myCItrad = new System.Globalization.CultureInfo("ZH-CN", true);
string sep = "";
foreach (DataColumn dc in dt.Columns)
{
HttpContext.Current.Response.Write(sep + dc.Caption);
sep = "\t";
}
HttpContext.Current.Response.Write("\n");
int i;
foreach (DataRow dr in dt.Rows)
{
sep = "";
for (i = 0; i < dt.Columns.Count; i++)
{
//因为有可能在字段中出现回车,所以需要先将回车替换掉.
//HttpContext.Current.Response.Write(sep + dr[i].ToString());
HttpContext.Current.Response.Write(sep + dr[i].ToString().Replace("\t", "").Replace("\n", "").Replace("\r", ""));
sep = "\t";
}
HttpContext.Current.Response.Write("\n");
}
HttpContext.Current.Response.End(); //不要执行后面的页面部分否则会把页面的内容也加到Excel后面
}
{
HttpContext.Current.Response.Clear();
HttpContext.Current.Response.ClearContent();
HttpContext.Current.Response.ClearHeaders();
HttpContext.Current.Response.Buffer = true; //仅仅是页面缓存
HttpContext.Current.Response.Charset = "GB2312";
HttpContext.Current.Response.AppendHeader("Content-Disposition", "attachment;filename=" + DateTime.Now.ToString("yyyyMMddHHmmss") + ".xls");
HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");//("GB2312");//设置输出流为简体中文
HttpContext.Current.Response.ContentType = "application/vnd.ms-excel";//设置输出文件类型为excel文件。
System.Globalization.CultureInfo myCItrad = new System.Globalization.CultureInfo("ZH-CN", true);
string sep = "";
foreach (DataColumn dc in dt.Columns)
{
HttpContext.Current.Response.Write(sep + dc.Caption);
sep = "\t";
}
HttpContext.Current.Response.Write("\n");
int i;
foreach (DataRow dr in dt.Rows)
{
sep = "";
for (i = 0; i < dt.Columns.Count; i++)
{
//因为有可能在字段中出现回车,所以需要先将回车替换掉.
//HttpContext.Current.Response.Write(sep + dr[i].ToString());
HttpContext.Current.Response.Write(sep + dr[i].ToString().Replace("\t", "").Replace("\n", "").Replace("\r", ""));
sep = "\t";
}
HttpContext.Current.Response.Write("\n");
}
HttpContext.Current.Response.End(); //不要执行后面的页面部分否则会把页面的内容也加到Excel后面
}
本文介绍了一个使用ASP.NET进行Excel文件导出的方法。该方法通过直接在客户端生成Excel文件,避免了服务器磁盘空间的占用。文章详细展示了如何设置HTTP响应头以确保文件正确下载,并提供了遍历数据集(DataTable)来构建Excel文件的具体步骤。

453

被折叠的 条评论
为什么被折叠?



