GridView格式化导出Excel

有时候需要按规则导出到Excel中,用模板的方法外,我提供一个简易的:

1 核心代码如下:

GridView格式化导出ExcelGridView格式化导出Excel   /**//// <summary>
GridView格式化导出Excel    
/// 导出到Excel
GridView格式化导出Excel    
/// </summary>
GridView格式化导出Excel    
/// <param name="sender"></param>
GridView格式化导出Excel    
/// <param name="e"></param>

GridView格式化导出Excel    protected void ButtonExcel_Click(object sender, EventArgs e)
GridView格式化导出ExcelGridView格式化导出Excel    
...{
GridView格式化导出Excel        Response.ClearContent();
GridView格式化导出Excel
GridView格式化导出Excel        Response.AddHeader(
"content-disposition""attachment; filename=ttt.xls");
GridView格式化导出Excel
GridView格式化导出Excel        Response.ContentType 
= "application/excel";
GridView格式化导出Excel
GridView格式化导出Excel        StringWriter sw 
= new StringWriter();
GridView格式化导出Excel
GridView格式化导出Excel        HtmlTextWriter htw 
= new HtmlTextWriter(sw);
GridView格式化导出Excel        
GridView格式化导出Excel        GridViewXinXiLan.RenderControl(htw);
GridView格式化导出Excel        Response.Write(sw);
GridView格式化导出Excel
GridView格式化导出Excel        Response.Write(
"<table><tr><td>fdsa</td><td>,df</td></tr></table>");
GridView格式化导出Excel        Response.Write(
"<font size=10 color=red>单位负责人:</font>");
GridView格式化导出Excel        Response.Write(
"<p>  ");
GridView格式化导出Excel        Response.Write(
"第二个测试  ");
GridView格式化导出Excel        Response.Write(
"<br>");
GridView格式化导出Excel        Response.Write(
"this is a test!");
GridView格式化导出Excel        Response.Write(
"<br>");
GridView格式化导出Excel        Response.Write(
"统计负责负责人:");
GridView格式化导出Excel
GridView格式化导出Excel        Response.End();
GridView格式化导出Excel
GridView格式化导出Excel    }

GridView格式化导出Excel
GridView格式化导出ExcelGridView格式化导出Excel    
/**//// <summary>
GridView格式化导出Excel    
/// 必须要的
GridView格式化导出Excel    
/// </summary>
GridView格式化导出Excel    
/// <param name="control"></param>

GridView格式化导出Excel    public override void VerifyRenderingInServerForm(Control control)
GridView格式化导出ExcelGridView格式化导出Excel    
...{
GridView格式化导出Excel
GridView格式化导出Excel    }

GridView格式化导出Excel

  Response.Write("<table><tr><td>单位负责人</td><td> </td><td>统计负责人:</td></tr></table>");

2 测试效果图

GridView格式化导出Excel

并且可以和表头设置相结合:

 

GridView格式化导出Excel protected void GridViewXinXiLan_RowCreated(object sender, GridViewRowEventArgs e)
GridView格式化导出ExcelGridView格式化导出Excel    
...{
GridView格式化导出Excel          
switch (e.Row.RowType)
GridView格式化导出ExcelGridView格式化导出Excel        
...{
GridView格式化导出Excel            
case DataControlRowType.Header:
GridView格式化导出Excel                
//第一行表头
GridView格式化导出Excel
                TableCellCollection tcHeader = e.Row.Cells;
GridView格式化导出Excel                tcHeader.Clear();
GridView格式化导出Excel                tcHeader.Add(
new TableHeaderCell());
GridView格式化导出Excel                tcHeader[
0].Attributes.Add("rowspan""3"); //跨Row
GridView格式化导出Excel
                tcHeader[0].Attributes.Add("bgcolor""white");
GridView格式化导出Excel                tcHeader[
0].Text = "";
GridView格式化导出Excel                tcHeader.Add(
new TableHeaderCell());
GridView格式化导出Excel                tcHeader[
1].Attributes.Add("bgcolor""Red");
GridView格式化导出Excel                tcHeader[
1].Attributes.Add("colspan""6"); //跨Column
GridView格式化导出Excel
                tcHeader[1].Text = "全部信息</th></tr><tr>";
GridView格式化导出Excel
GridView格式化导出Excel                
//第二行表头
GridView格式化导出Excel
                tcHeader.Add(new TableHeaderCell());
GridView格式化导出Excel                tcHeader[
2].Attributes.Add("bgcolor""DarkSeaGreen");
GridView格式化导出Excel                tcHeader[
2].Text = "身份证号码";
GridView格式化导出Excel                tcHeader.Add(
new TableHeaderCell());
GridView格式化导出Excel                tcHeader[
3].Attributes.Add("bgcolor""LightSteelBlue");
GridView格式化导出Excel                tcHeader[
3].Attributes.Add("colspan""2");
GridView格式化导出Excel                tcHeader[
3].Text = "基本信息";
GridView格式化导出Excel                tcHeader.Add(
new TableHeaderCell());
GridView格式化导出Excel                tcHeader[
4].Attributes.Add("bgcolor""DarkSeaGreen");
GridView格式化导出Excel                tcHeader[
4].Text = "福利";
GridView格式化导出Excel                tcHeader.Add(
new TableHeaderCell());
GridView格式化导出Excel                tcHeader[
5].Attributes.Add("bgcolor""LightSteelBlue");
GridView格式化导出Excel                tcHeader[
5].Attributes.Add("colspan""2");
GridView格式化导出Excel                tcHeader[
5].Text = "联系方式</th></tr><tr>";
GridView格式化导出Excel
GridView格式化导出Excel                
//第三行表头
GridView格式化导出Excel
                tcHeader.Add(new TableHeaderCell());
GridView格式化导出Excel                tcHeader[
6].Attributes.Add("bgcolor""Khaki");
GridView格式化导出Excel                tcHeader[
6].Text = "身份证号码";
GridView格式化导出Excel                tcHeader.Add(
new TableHeaderCell());
GridView格式化导出Excel                tcHeader[
7].Attributes.Add("bgcolor""Khaki");
GridView格式化导出Excel                tcHeader[
7].Text = "姓名";
GridView格式化导出Excel                tcHeader.Add(
new TableHeaderCell());
GridView格式化导出Excel                tcHeader[
8].Attributes.Add("bgcolor""Khaki");
GridView格式化导出Excel                tcHeader[
8].Text = "出生日期";
GridView格式化导出Excel                tcHeader.Add(
new TableHeaderCell());
GridView格式化导出Excel                tcHeader[
9].Attributes.Add("bgcolor""Khaki");
GridView格式化导出Excel                tcHeader[
9].Text = "薪水";
GridView格式化导出Excel                tcHeader.Add(
new TableHeaderCell());
GridView格式化导出Excel                tcHeader[
10].Attributes.Add("bgcolor""Khaki");
GridView格式化导出Excel                tcHeader[
10].Text = "家庭住址";
GridView格式化导出Excel                tcHeader.Add(
new TableHeaderCell());
GridView格式化导出Excel                tcHeader[
11].Attributes.Add("bgcolor""Khaki");
GridView格式化导出Excel                tcHeader[
11].Text = "邮政编码";
GridView格式化导出Excel                
break;
GridView格式化导出Excel        }

GridView格式化导出Excel    }

 

效果图:

GridView格式化导出Excel

转载于:https://www.cnblogs.com/angelfeather/archive/2008/06/18/1224790.html