如何写多个excel表数据

时间:2010-08-09 03:17:19

标签: c# excel datatable asp.net-3.5

我有3个数据表。我需要在excel表中写下这三个数据表数据。  因为我们知道在一张excel表格下我可以拥有(超过1张)。

以同样的方式我需要将我的3个数据表数据写入一个excel(其中sheet1将表示dattable1,sheet2将表示dattable2,表3将表示数据表3)

这是我用于将数据表数据写入网格然后进入excel

的代码
private void DataTableToExcel(DataTable dtResult)
        {
            try
            {
                DataGrid grid = new DataGrid();
                grid.HeaderStyle.Font.Bold = true;
                grid.DataSource = dtResult;
                grid.DataBind();
                // render the DataGrid control to a file
                using (StreamWriter sw = new StreamWriter(Server.MapPath("Report/Report.xls")))
                {
                    using (HtmlTextWriter hw = new HtmlTextWriter(sw))
                    {
                        grid.RenderControl(hw);
                    }
                }
                string filePath = Server.MapPath("~/" + "Report" + "/" + "Report.xls");
                System.IO.FileInfo targetFile = new System.IO.FileInfo(filePath);
                if (targetFile.Exists)
                {
                    Response.Clear();
                    string shortDate = DateTime.Now.ToShortDateString();
                    // Response.AddHeader("Content-Disposition", "attachment; filename=" + "Test");
                    Response.AddHeader("Content-Disposition", "attachment; filename=" + "Emp" + shortDate + ".xls");
                    Response.AddHeader("Content-Length", targetFile.Length.ToString());
                    Response.ContentType = "application/vnd.ms-excel";
                    Response.WriteFile(targetFile.FullName);
                }
            }
            catch (Exception ex)
            {
                WriteLogError(ex.Message);
            }
        }

任何关于这个问题的帮助都会受到赞赏。  感谢。

1 个答案:

答案 0 :(得分:0)

您可以使用NPOI for C#实现此目的。真的很容易使用。

看一下这些链接:

Create Excel (.XLS and .XLSX) file from C#

Creating Excel spreadsheets .XLS and .XLSX in C#

您可以使用以下内容引用工作簿中的每个工作表:

 // Getting the worksheet by its name...
 HSSFSheet sheet = templateWorkbook.GetSheet("Sheet1");