现在的位置: 首页 > 综合 > 正文

Asp.net导出Excel(一)

2013年10月22日 ⁄ 综合 ⁄ 共 1552字 ⁄ 字号 评论关闭

(1)使用DataTable导出Excel
     其中使用StringWriter类:将信息写入字符串。其命名空间为:System.IO

      具体的原理是:
      首先读取DataTable中的列名,然后循环读取DataTable行值。
      然后设置导出的编码,导出的类型。
      最后输出StringWriter对象即可。
      这种导出是将文件直接以文件流的形式输出到浏览器。

   

  1. private  StringWriter GetStringWriter(DataTable dt)  
  2.     {  
  3.         StringWriter sw = new StringWriter();  
  4.         //读列名  
  5.         foreach (DataColumn dc in dt.Columns)  
  6.             sw.Write(dc.ColumnName + "\t");  
  7.         //读列值  
  8.         //重新的一行  
  9.         sw.Write(sw.NewLine);  
  10.               if (dt != null)  
  11.         {  
  12.             foreach (DataRow dr in dt.Rows)  
  13.             {  
  14.                 for (int i = 0; i < dt.Columns.Count; i++)  
  15.                 {  
  16.                     sw.Write(dr[i].ToString() + "\t");  
  17.                 }  
  18.                 sw.Write(sw.NewLine);  
  19.             }  
  20.         }  
  21.         sw.Close();  
  22.               
  23.         return sw;  
  24.     }  
  1. protected void ExcelImport(DataTable dt, string ExportFileName)  
  2.     {  
  3.         StringWriter sw = GetStringWriter(dt);  
  4.         //当前编码  
  5.         HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");  
  6.         //把输出的文件名进行编码  
  7.         string fileName = HttpUtility.UrlEncode (ExportFileName, System.Text.Encoding.UTF8);  
  8.         //文件名  
  9.         string str = "attachment;filename=" + fileName + ".xls";  
  10.         //把文件头输出,此文件头激活文件下载框  
  11.         HttpContext.Current.Response.AppendHeader("Content-Disposition", str);//http报头文件  
  12.         HttpContext.Current.Response.ContentType = "application/ms-excel";  
  13.         this.Page.EnableViewState = false;  

抱歉!评论已关闭.