• C#:excel导入导出


    资源:excelService 服务 http://download.csdn.net/detail/istend/8060501

    • 排列问题

    导出时,数字和字符的排列格式默认不一样,数字靠右,字符靠左,想让排列一致,有两个办法:

    1 在绑定时,就做固定格式

    2 导出时,将数字那一列转换为文本格式,例如以下

    protected void myGridView_RowDataBound(object sender, GridViewRowEventArgs e)  
    {  
                if (e.Row.RowType == DataControlRowType.DataRow)  
                {  
    //让数字以文本形式表示   
                    e.Row.Cells[4].Attributes.Add("style", "vnd.ms-excel.numberformat:@");  
    }  
    }  
    
    • 转换函数
            /// <summary>
            /// 导出button
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void btnExport_Click(object sender, System.Web.UI.ImageClickEventArgs e)
            {
                //导出文件名称
                string strFileName = "报表.xls";
    
                //取原始数据。并绑定
                this.dagInfo.AllowPaging = false;
                this.dagInfo.AllowSorting = false;
                DataTable dt = BingData();
                this.dagInfo.DataSource = dt;
                this.dagInfo.DataBind();
                //使用本页面直接输出
                WHPT_WebApp.Statistics.GridStyleReport.ToExcel(this.dagInfo
                    , strFileName,
                    delegate(System.Web.UI.HtmlTextWriter writer)
                    {
                        writer.Write(string.Format("<table width=100%><tr><td align=center colspan=5>{0}</td></tr></table>", "报表"));
                    }
                    , null);
    
                //恢复分页数据
                this.dagInfo.AllowPaging = true;
                this.dagInfo.AllowSorting = true;
                BindInfo(1, "");
                return;
            }
    
            #endregion


            /// <summary>
            /// 转换成EXCEL
            /// </summary>
            /// <param name="ctl"></param>
            /// <param name="file_name"></param>
            public static void ToExcel(System.Web.UI.Control ctl, string file_name,RenderCallBack beforeRende,RenderCallBack afterRender)
            {
                //将控件数据导出成Excel文件
                if (string.IsNullOrEmpty(file_name))
                    return;
                HttpContext.Current.Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(file_name, System.Text.Encoding.UTF8));
                HttpContext.Current.Response.Charset = "GB2312"; //"UTF-8";				
                HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.Default;
                HttpContext.Current.Response.ContentType = "application/ms-excel";//image/JPEG;text/HTML;image/GIF;vnd.ms-excel/msword
                ctl.Page.EnableViewState = true;
                System.IO.StringWriter tw = new System.IO.StringWriter();
                System.Web.UI.HtmlTextWriter hw = new System.Web.UI.HtmlTextWriter(tw);
                if (beforeRende != null)
                    beforeRende(hw);
                ctl.RenderControl(hw);
                if (afterRender != null)
                    afterRender(hw);
                HttpContext.Current.Response.Write(GetHtmlHeadText(tw.ToString()));
                HttpContext.Current.Response.End();
    
            }


     

    PS:此文仅做记录交流所用。不做他用


  • 相关阅读:
    ORACLE触发器具体解释
    秒杀多线程第四篇 一个经典的多线程同步问题
    Java中Integer类的方法
    九大排序算法再总结
    删除条目时的确认对话框
    VirtualBox安装及使用说明和虚拟机安装XP系统图文教程
    J2EE之验证码实现
    教你用笔记本破解无线路由器password
    vSphere HA状况:未知配置错误解决的方法
    HDU 2504 又见GCD
  • 原文地址:https://www.cnblogs.com/zhchoutai/p/8594341.html
Copyright © 2020-2023  润新知