在Baidu中一找"GridView导出到Excel"可以很顺利的找到我贴到下面的代码,很多人依照代码使用,发现以下几个问题:
(1)StringWriter 不能用,因为没有引入命名空间System.IO
(2)Encoding不能用,因为没有引入命名空间System.Text
(3)在用户控件上使用的GridView不能重写VerifyRenderingInServerForm函数。
一、GridView数据导出到Excel文件中
1 protected void Button1_Click(object sender, EventArgs e)
2 {
3 Export("application/ms-excel", "自命名文件名.xls");
4 }
5
6 private void Export(string FileType, string FileName)
7 {
8 Response.Charset = "GB2312";
9 Response.ContentEncoding = System.Text.Encoding.UTF7;
10 Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode (FileName, Encoding.UTF8).ToString());
11 Response.ContentType = FileType;
12 this.EnableViewState = false;
13 StringWriter tw = new StringWriter();
14 HtmlTextWriter hw = new HtmlTextWriter(tw);
15 GridView1.RenderControl(hw);
16 Response.Write(tw.ToString());
17 Response.End();
18 }
19 //如果没有下面方法会报错类型“GridView”的控件“GridView1”必须放在具有 runat=server 的窗体标记内
20 public override void VerifyRenderingInServerForm(Control control)
21 {
22 }
二、Excel数据导入到GridView中
1 //读取Excel数据的代码:这个很简单的
2 private DataSet CreateDataSource()
3 {
4 string strCon;
5 strCon = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Server.MapPath("excel.xls") + "; Extended Properties=Excel 8.0;";
6 OleDbConnection olecon = new OleDbConnection(strCon);
7 OleDbDataAdapter myda = new OleDbDataAdapter("SELECT * FROM [Sheet1$]", strCon);
8 DataSet myds = new DataSet();
9 myda.Fill(myds);
10 return myds;
11 }
12 protected void Button1_Click(object sender, EventArgs e)
13 {
14 GridView1.DataSource = CreateDataSource();
15 GridView1.DataBind();
16 }
【说明】
1、上面的例子网站上到处都有,我这里只是贴出来而已;
2、上述例子的代码是正确的,绝对没有语法错误;
3、但是,上面的代码只能是针对于GridView控件直接在aspx页面上,如果在用户控件上使用了GridView控件,那么你必须按照以下方式处理了
三、用户控件上的GridView如何导出到Excel表
1、前面步骤跟前面的一样,你需要一个按钮来处理导入/导出事件
2、你需要把用户控件放到某个页面上,如Test.aspx
3、如果你仅仅这样,页面肯定会报错。
4、为了避免错误,你必须在Test.aspx页面把第一行改成(红色为添加进去的)
<%@ Page Language="C#" EnableEventValidation = "false" AutoEventWireup="true" CodeFile="SysUser.aspx.cs" Inherits="Autho_SysUser2" %>
5、然后在Test.aspx.cs中重写
public override void VerifyRenderingInServerForm(Control control)
{
//函数体内没有任何代码,切记
}
6、浏览网页即可使用