DataGrid输出Excel并进行格式化处理

private   void  Page_Load( object  sender, System.EventArgs e)
{
    DataGrid1.DataSource 
=  CreateDataSource();
    DataGrid1.DataBind();
}

ICollection CreateDataSource()
{
    DataTable dt 
=   new  DataTable();
    DataRow dr;
    dt.Columns.Add(
new  DataColumn( " 身份证号码 " typeof ( string )));
    dt.Columns.Add(
new  DataColumn( " 图书单价 " typeof ( decimal )));
    dt.Columns.Add(
new  DataColumn( " 购买数量 " typeof (Int32)));
    dt.Columns.Add(
new  DataColumn( " 总价格 " typeof ( decimal )));

    
for ( int  i  =   0 ; i  <   30 ; i ++ )
    {
        dr 
=  dt.NewRow();
        dr[
0 =   " 123456789123456789 " ;
        dr[
1 =   100   *  i  /   3.0 ;
        dr[
2 =  i  +   5 ;
        dr[
3 =  ( decimal )dr[ 1 *  ( int )dr[ 2 ];

        dt.Rows.Add(dr);
    }

    DataView dv 
=   new  DataView(dt);

    
return  dv;

}

private   void  Button1_Click( object  sender, EventArgs e)
{
    Response.Clear();
    Response.Buffer 
=   true ;
    Response.Charset 
=   " GB2312 " ;
    Response.AppendHeader(
" Content-Disposition " " attachment;filename=FileName.xls " );
    
// 设置输出流为简体中文
    Response.ContentEncoding  =  System.Text.Encoding.GetEncoding( " GB2312 " );
    
// 设置输出文件类型为Excel文件
    Response.ContentType  =   " application/ms-excel " ;
    EnableViewState 
=   true ;
    System.Globalization.CultureInfo myCItrad 
=   new  System.Globalization.CultureInfo( " ZH-CN " , true );
    System.IO.StringWriter oStringWriter 
=   new  System.IO.StringWriter(myCItrad); 
    System.Web.UI.HtmlTextWriter oHtmlTextWriter 
=   new  System.Web.UI.HtmlTextWriter(oStringWriter);
    
this .DataGrid1.RenderControl(oHtmlTextWriter); 
    Response.Write(oStringWriter.ToString());
    Response.End();
}

private   void  DataGrid1_ItemDataBound( object  sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
{
    
if (e.Item.ItemType  ==  ListItemType.Item  ||  e.Item.ItemType  ==  ListItemType.AlternatingItem)
    {
        e.Item.Cells[
0 ].Attributes.Add( " style " , " vnd.ms-excel.numberformat:@ " );
        e.Item.Cells[
3 ].Attributes.Add( " style " , " vnd.ms-excel.numberformat:¥#,###.00 " );
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值