如何使用 C# 将 XL 工作表名称指定到数据表中 ASP.NET

本文关键字:数据表 NET ASP 何使用 XL 工作 | 更新日期: 2023-09-27 18:31:22

>我正在单个XL文件中导出三个工作表。但是我得到一个工作表名称,如表1,表2,表3。

下面是无需调用数据库即可正常工作的 C# 代码工作表名称。

   var ds = new DataSet();
   var dt = new DataTable("TableName For Sheet1");
   dt.Columns.Add("col1");
   dt.Columns.Add("col2");
   dt.Rows.Add("Value1", "Value2");
   var dt2 = new DataTable("TableName For Sheet2");
   dt2.Columns.Add("col1");
   dt2.Columns.Add("col2");
   dt2.Rows.Add("Value1", "Value2");
   ds.Tables.Add(dt);
   ds.Tables.Add(dt2);
   ExcelHelper.ToExcel(ds, "test.xls", Page.Response);

下面是用于调用数据库存储过程的 C# 代码,但工作表名称被赋予表 1、表 2、表 2。

    DataSe ds = new DataSet();
    DataTable dt = new DataTable("Registration Details");
    DataTable dt1 = new DataTable("Education Details");
    DataTable dt2 = new DataTable("Employeement Details");

    dt = bl.Get_Registrationdetailsbydate(bo);
    gv_Regdetails.DataSource = dt;
    gv_Regdetails.DataBind();
    dt1 = bl.Get_Registrationdetailsbydate1(bo);
    dt2 = bl.Get_Registrationdetailsbydate2(bo);
    DataTable filteredEducation = dt1.AsEnumerable()
                                     .Where(x => dt.AsEnumerable()
                               .Any(z => z.Field<string>("Email").Trim() == x.Field<string>("Email").Trim()))
                               .CopyToDataTable();
    DataTable filteredEmployee = dt2.AsEnumerable()
                                    .Where(x => dt.AsEnumerable()
                              .Any(z => z.Field<string>("Email").Trim() == x.Field<string>("Email").Trim()))
                              .CopyToDataTable();
    ds.Tables.Add(dt);
    ds.Tables.Add(filteredEducation);
    ds.Tables.Add(filteredEmployee);
    ExcelHelper.ToExcel(ds, "DangoteUsers.xls", Page.Response);

我需要表格名称结果,例如注册详细信息,教育详细信息和员工详细信息。

我参考这个例子:http://www.codeproject.com/Articles/31516/Export-DataSet-to-Multiple-Excel-Sheets

如何使用 C# 将 XL 工作表名称指定到数据表中 ASP.NET

初始化后,您正在覆盖dtdt1dt2,这就是为什么您没有正确获取名称,而是获取表的默认名称。尝试在分配后设置这三个表的名称,或在分配逻辑中包含表名称。我更新了您的代码来演示这一点。

DataSet ds = new DataSet();

var dt = bl.Get_Registrationdetailsbydate(bo);
gv_Regdetails.DataSource = dt;
gv_Regdetails.DataBind();
var dt1 = bl.Get_Registrationdetailsbydate1(bo);
var dt2 = bl.Get_Registrationdetailsbydate2(bo);
DataTable filteredEducation = dt1.AsEnumerable()
                                 .Where(x => dt.AsEnumerable()
                           .Any(z => z.Field<string>("Email").Trim() == x.Field<string>("Email").Trim()))
                           .CopyToDataTable();
DataTable filteredEmployee = dt2.AsEnumerable()
                                .Where(x => dt.AsEnumerable()
                          .Any(z => z.Field<string>("Email").Trim() == x.Field<string>("Email").Trim()))
                          .CopyToDataTable();
dt.TableName = "Registration Details";
filteredEducation.TableName = "Education Details";
filteredEmployee.TableName = "Employeement Details";
ds.Tables.Add(dt);
ds.Tables.Add(filteredEducation);
ds.Tables.Add(filteredEmployee);
ExcelHelper.ToExcel(ds, "DangoteUsers.xls", Page.Response);