日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

《WebForm开发系列高级篇》Item2导出EXCEL通用类(GridView,DataList,Repeater,DetailView)

發布時間:2025/3/21 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 《WebForm开发系列高级篇》Item2导出EXCEL通用类(GridView,DataList,Repeater,DetailView) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1.導出效果圖:

2.C#導出EXCEL通用類源代碼:

using System;

using System.Data;

using System.Configuration;

using System.Linq;

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.HtmlControls;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Xml.Linq;

using System.IO;

using System.Text;

using System.Drawing;

///

///CommonClass 的摘要說明

///

public class CommonClass

{

public CommonClass()

{

//

//TODO: 在此處添加構造函數邏輯

//

}

public static void ReportToExcel(System.Web.UI.Control ctl, string fileName)

{

HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.UTF7;

HttpContext.Current.Response.ContentType = "application/ms-excel";

HttpContext.Current.Response.Charset = "gb2312";

HttpContext.Current.Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(fileName + ".xls", Encoding.UTF8).ToString());

ClearChildControls(ctl);

StringWriter sw = new StringWriter();

HtmlTextWriter htw = new HtmlTextWriter(sw);

ctl.RenderControl(htw);

HttpContext.Current.Response.Write(sw.ToString());

HttpContext.Current.Response.End();

}

private static void RecursiveClear(Control control)

{

for (int i = control.Controls.Count - 1; i >= 0; i--)

{

RecursiveClear(control.Controls[i]);

}

if (control is Repeater)

{

control.Parent.Controls.Remove(control);

}

else if (control is LinkButton)

{

LiteralControl literal = new LiteralControl();

control.Parent.Controls.Add(literal);

literal.Text = ((LinkButton)control).Text;

control.Parent.Controls.Remove(control);

}

else if (control is Button)

{

control.Parent.Controls.Remove(control);

}

else if (control is System.Web.UI.WebControls.Image)

{

if (((System.Web.UI.WebControls.Image)control).Visible)

{

control.Parent.Controls.Add(new LiteralControl("o"));

}

control.Parent.Controls.Remove(control);

}

else if (control is ListControl)

{

LiteralControl literal = new LiteralControl();

control.Parent.Controls.Add(literal);

try

{

literal.Text = ((ListControl)control).SelectedItem.Text;

}

catch

{

}

control.Parent.Controls.Remove(control);

}

return;

}

protected static void ClearChildControls(Control dg1)

{

if (dg1 is GridView)

{

GridView dg = (GridView)dg1;

for (int i = dg.Columns.Count - 1; i >= 0; i--)

{

if (dg.Columns[i].GetType().Name == "ButtonColumn"

|| dg.Columns[i].GetType().Name == "CheckBoxField"

|| dg.Columns[i].GetType().Name == "CommandField")

{

dg.Columns[i].Visible = false;

}

}

RecursiveClear(dg1);

}

else

{

RecursiveClear(dg1);

}

}

}

3.調用方法:

CommonClass.ReportToExcel(GridView1, "從GridView導出的EXCEL");(責任編輯:51CSharp.net)

轉載于:https://www.cnblogs.com/Sue_/articles/1663422.html

總結

以上是生活随笔為你收集整理的《WebForm开发系列高级篇》Item2导出EXCEL通用类(GridView,DataList,Repeater,DetailView)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。