代码如下:
#region 导出Excel
/// <summary>
/// 导出Datagrid里所有数据到Office
/// </summary>
/// <param name="grdTemp">要导出的Datagrid</param>
/// <param name="dsTemp">Datagrid的数据源</param>
public void DataGridToExcel(DataGrid grdTemp,DataSet dsTemp)
{
grdTemp.AllowPaging=false; //设置不能分页
grdTemp.DataSource=this.dsTemp; //重新绑定数据源
grdTemp.DataBind();
//常规导出方法
System.IO.StringWriter SW = new System.IO.StringWriter();
System.Web.UI.HtmlTextWriter HTW=new System.Web.UI.HtmlTextWriter(SW);
grdTemp.RenderControl(HTW);
//Page为要导出的对象,当前是Page,如果是DataGrid,DataList等都可以
Response.Buffer=true;
Response.Clear();
Response.ClearContent();
Response.ClearHeaders();
Response.ContentType = "application/vnd.ms-excel";
//Response.ContentType是输出流的 HTTP MIME 类型
//Response.ContentType --- word文件
//application/vnd.ms-excel --- excel文件
//...
Response.Charset="utf-8";
Response.ContentEncoding=System.Text.Encoding.GetEncoding("utf-8");
Response.AddHeader("Content-Disposition", "attachment;filename=aaa.xls");
//attachment --- 作为附件下载
//inline --- 在线打开
//filename如过是中文,则可以用HttpUtility.UrlEncode(fileName,System.Text.Encoding.UTF8)
//进行进行编码,以解决文件名乱码的问题
Response.Write(SW.ToString());
Response.Flush();
Response.Close();
}
#endregion
将当前的页面导出成一个Word文件.同样原理要将DataGrid,DataList等中的内容导出为Word或Excel等类型的文件,那么只需要稍做修改代码即可.
本文介绍了一种简单的方法来将ASP.NET中的Datagrid数据导出到Excel或Word文件中。通过利用Response对象及相关的IO操作,可以轻松地完成这一任务。文章提供了具体的代码示例,并解释了如何调整响应头以便正确处理文件类型和中文文件名。
6890

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



