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

本文介绍了一个使用ASP.NET进行数据展示并导出到Excel文件的例子。通过创建一个包含身份证号码、图书单价等字段的数据表,并将其绑定到DataGrid中显示。此外,还提供了一个按钮点击事件来实现将DataGrid中的数据导出到Excel的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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");
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值