asp.net导出的excel表

风吹得好舒服 2013-10-05 05:16:03
asp.net导出的excel表 自动套用格式怎么去掉
   
private void Export(string FileType, string FileName)
{
Response.Charset = "GB2321";
Response.ContentEncoding = System.Text.Encoding.UTF7;
Response.AddHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(FileName, System.Text.Encoding.UTF8).ToString());
Response.ContentType = FileType;
this.EnableViewState = false;
StringWriter sw = new StringWriter();
HtmlTextWriter hw = new HtmlTextWriter(sw);
GridView1.RenderControl(hw);
Response.Write(sw.ToString());
Response.End();
}
...全文
206 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
引用 2 楼 ivyvae 的回复:
不好意思 我还是没太懂你的意思。 我现在需要导出excel,并且已经实现了导出,以上是导出方法的代码,但是导出的excel中有GridView自动套用的格式,比如说颜色。。。现在需要导出不带套用格式的GridView中的数据。。。求指点。
你可以copy当前的aspx成为一个新的aspx,删除所有无关的控件全都去掉,把GridView上的各种复杂样式(包括asp.net Theme)去掉,仅剩下“素颜”的表格。导出数据可以用这个新的aspx,它完全没有必要跟用来交互编辑数据的aspx长的一样! 比如说你的“导出”按钮,不要在当前页面去下载,而是打开新的窗口。例如可以写
Session["output数据"] = this.ObjectDataSource1.Select();   //使用当前数据源的Select()方法提取数据
ClientScript.RegisterStartupScript(this.GetType(), "导出",
    string.Format("window.open(\"{0}\",\"_blank\");", this.Page.ResolveUrl("~/output.aspx"))
    , true);
这样,你的另一个页面 output.aspx 读取 Session["output数据"] 绑定到 GridView 上,再“导出excel”。由于这个页面是从当前页面copy来的,然后简化的,因此其实很容易生成。 大多数浏览器都有这样的功能,如果一个新弹出的页面标记了 Content-Disposition 头,在页面下载完毕之后,页面会自动关闭。不需要你再 output.aspx 页面中写关闭页面的脚本。
  • 打赏
  • 举报
回复
asp.net 现在应该很少用GridView这样的控键了吧。 建议自己画表格,在负责导出的中对样式进行过滤或者在新窗口中完成导出,新窗口不写样式就行,但是要求border属性必须设置,否则导出的excel将是没有线的。
generhappy 2013-10-06
  • 打赏
  • 举报
回复
如果要导出excel 最好不要在当前页面导出,而是跳转至新页面,在新页面读出要导出的数据,而且也不用分页,前台记得设置一下, <meta http-equiv="content-type" content="application/ms-excel; charset=UTF-8"/> 后台page_load里执行如下函数就行了!


 private void DataSetToExcel(string FileName)
        {
            //创建获取要导出的excel   
            DataSet ds = CreatDataSet();

            string style = "<style>td{mso-number-format:\"\\@\";}</style>";//防止导出excel时将以0开头的全数字数据的0去掉
            DateTime now = System.DateTime.Now;
            HttpContext.Current.Response.Clear();
            HttpContext.Current.Response.Charset = "";
            HttpContext.Current.Response.ContentType = "application/vnd.ms-xls";
            StringWriter stringWrite = new StringWriter();
            HtmlTextWriter htmlWrite = new HtmlTextWriter(stringWrite);

            DataGrid dg = new DataGrid();
            dg.DataSource = ds;
            dg.DataBind();
            dg.RenderControl(htmlWrite);
            HttpContext.Current.Response.AddHeader("content-disposition", "attachment;filename=" + HttpUtility.UrlEncode(now.ToString() + ".xls"));
            HttpContext.Current.Response.Write(style);
            HttpContext.Current.Response.Write(stringWrite.ToString());
            HttpContext.Current.Response.End();
        }  
风吹得好舒服 2013-10-05
  • 打赏
  • 举报
回复
引用 1 楼 sp1234 的回复:
另外设计一个aspx,不要在当前的aspx中“导出excel”。 当前页面,可以使用 window.open(url,"blank") 方式调用你的另外一个aspx,大多数浏览器都会直接下载这个所谓excel之后立刻自动关闭这个窗口(而不是留下一个空白窗口)。
不好意思 我还是没太懂你的意思。 我现在需要导出excel,并且已经实现了导出,以上是导出方法的代码,但是导出的excel中有GridView自动套用的格式,比如说颜色。。。现在需要导出不带套用格式的GridView中的数据。。。求指点。
  • 打赏
  • 举报
回复
另外设计一个aspx,不要在当前的aspx中“导出excel”。 当前页面,可以使用 window.open(url,"blank") 方式调用你的另外一个aspx,大多数浏览器都会直接下载这个所谓excel之后立刻自动关闭这个窗口(而不是留下一个空白窗口)。

62,041

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧