Export search results to excel in MVC 4

后端 未结 1 711
暖寄归人
暖寄归人 2021-01-28 08:46

I have following controller. When i search for a specific grade i get a list. What i want is to export this result to excel. I have my export button works fine. But the only thi

相关标签:
1条回答
  • 2021-01-28 09:07

    Your ExportData() action is just retrieving every result from db.students, it doesn't know what is in your view.
    Assuming your list of students has all the data you want, you could either post the entire list to your action, e.g.

    public ActionResult ExportData(List<Student> students)
    {
        GridView gv = new GridView();
        gv.DataSource = students;
        gv.DataBind();
        Response.ClearContent();
        Response.Buffer = true;
        Response.AddHeader("content-disposition", "attachment; filename=students.xls");
        Response.ContentType = "application/ms-excel";
        Response.Charset = "";
        StringWriter sw = new StringWriter();
        HtmlTextWriter htw = new HtmlTextWriter(sw);
        gv.RenderControl(htw);
        Response.Output.Write(sw.ToString());
        Response.Flush();
        Response.End();
    
        return RedirectToAction("Home");
    }  
    

    Or you could pass your search parameters and filter the database accordingly, e.g.

    public ActionResult ExportData(string searchBy, string search)
    {
    
        GridView gv = new GridView();
        if (!String.IsNullOrEmpty(searchBy) && !String.IsNullOrEmpty(search))
        {
            if (searchBy == "ID")
            {
                gv.DataSource = db.students.Where(x => x.id==search).ToList();
            }
            else if (searchBy == "grade")
            {
                gv.DataSource = db.students.Where(x => x.grade == search).ToList();
            }
        }
        gv.DataBind();
        Response.ClearContent();
        Response.Buffer = true;
        Response.AddHeader("content-disposition", "attachment; filename=students.xls");
        Response.ContentType = "application/ms-excel";
        Response.Charset = "";
        StringWriter sw = new StringWriter();
        HtmlTextWriter htw = new HtmlTextWriter(sw);
        gv.RenderControl(htw);
        Response.Output.Write(sw.ToString());
        Response.Flush();
        Response.End();
    
        return RedirectToAction("Home");
    }
    

    And don't forget to post the necessary data from your view.

    0 讨论(0)
提交回复
热议问题