我的页面大概是这样的:两个gridview(一个用来存放计算的原始数据,一个用来存放结果数据,然后把结果数据导出到excel中)用户添加原始数据有两种方式:一种是在线添加原始数据,还有一种是通过把txt文件中的数据导入到gridview中去,其中第二种方法,我在界面添加了FileUpload 供用户上传要导入数据的文件,现在遇到的问是:之前没有加第二种方法的时候 结果数据导出到excel 完全正常,但是后来加了一个FileUpload 以实现用户把文件数据导入到gridview,但是加了一个FileUpload 控件后 结果数据导出到excel 就不正常了,打开导出的excel 提示什么文件丢失,并且导出内容还有界面上的控件 ,和之前只导出结果数据完全不同,然后我把FileUpload 屏蔽后,导出的excel又完全正常,现在很是费解 请大家帮忙 谢谢
#region excel //这段把gridview中的数据导出excel的代码应该没有问题
/// <summary>
/// 导出为Excel
/// </summary>
/// <param name="ctl">控件ID</param>
/// <param name="FileName">文件名</param>
public static void ToExcel(System.Web.UI.Control ctl, string FileName)
{
HttpContext.Current.Response.Charset = "UTF8";
HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.GetEncoding("utf-7");
HttpContext.Current.Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(FileName, System.Text.Encoding.UTF8));
HttpContext.Current.Response.ContentType = "application/ms-excel"; //image/JPEG;text/HTML;image/GIF;vnd.ms-excel/msword
ctl.Page.EnableViewState = false;
System.IO.StringWriter tw = new System.IO.StringWriter();
HtmlTextWriter hw = new HtmlTextWriter(tw);
ctl.RenderControl(hw);
HttpContext.Current.Response.Write(tw.ToString());
HttpContext.Current.Response.End();
}
#endregion
4 回答
慕斯709654
TA贡献1840条经验 获得超5个赞
ctl是什么,这个控件里面是不是包含了FileUpload控件,如果包含的话,导出时就会将该控件也渲染到你的excel中去,尝试将
FileUpload放到ctl之外,或者导出之前替换ctl中的服务器控件
public class ExcelHelper { public static void PrepareControlForExport(System.Web.UI.Control control) { for (int i = 0; i < control.Controls.Count; i++) { System.Web.UI.Control current = control.Controls[i]; if (current is LinkButton) { control.Controls.Remove(current); control.Controls.AddAt(i, new LiteralControl((current as LinkButton).Text)); } else if (current is ImageButton) { control.Controls.Remove(current); control.Controls.AddAt(i, new LiteralControl((current as ImageButton).AlternateText)); } else if (current is HyperLink) { control.Controls.Remove(current); control.Controls.AddAt(i, new LiteralControl((current as HyperLink).Text)); } else if (current is DropDownList) { control.Controls.Remove(current); control.Controls.AddAt(i, new LiteralControl((current as DropDownList).SelectedItem.Text)); } else if (current is CheckBox) { control.Controls.Remove(current); control.Controls.AddAt(i, new LiteralControl((current as CheckBox).Checked ? "True" : "False")); } if (current.HasControls()) { PrepareControlForExport(current); } } } }
调用
ExcelHelper.PrepareControlForExport(GridView1);
就可以替换其中的服务器控件,方法可能需要你再扩充下
另外,页面中需要有
public override void VerifyRenderingInServerForm(Control control)
{
}
- 4 回答
- 0 关注
- 447 浏览
添加回答
举报
0/150
提交
取消