asp.net 读取数据库生成excel

 

public void DataGridToExcel(GridView grdTemp, DataSet dsTemp, string strTitle)
    {
        strTitle = HttpUtility.UrlEncode(strTitle.Trim(), System.Text.Encoding.UTF8); //编码转换
        grdTemp.AllowPaging = false; //设置不能分页
        grdTemp.DataSource = 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=" + strTitle + ".xls");
        //attachment --- 作为附件下载
        //inline --- 在线打开
        //filename如过是中文,则可以用
        strTitle = HttpUtility.UrlEncode(strTitle, System.Text.Encoding.UTF8);
        //进行进行编码,以解决文件名乱码的问题
        Response.Write(SW.ToString());

        Response.Flush();
        Response.Close();
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值