0

我想知道如何在下面的代码中传递不止一个“工作表”?
我正在使用 Selenium C# 在 Web 应用程序中填写一些数据,当“Sheet1”上的信息被填满时,我必须继续填写“Sheet2”中的信息。下面的代码只是传入“Sheet 1”。我怎样才能增强它,以便我能够在那里获得多张纸?

public DataTable ExcelToDataTable(string filename)    
{
    FileStream stream = File.Open(filename, FileMode.Open, FileAccess.Read);
    IExcelDataReader excelReader = ExcelReaderFactory.CreateOpenXmlReader(stream);

    DataSet result = excelReader.AsDataSet(new ExcelDataSetConfiguration()
    {
        ConfigureDataTable = (_) => new ExcelDataTableConfiguration()
        {
            UseHeaderRow = true
        }
    });

    DataTableCollection table = result.Tables;
    DataTable resultTable = table["sheet1"]; //here I'd like to have more than just one "sheet"

    return resultTable;    
}
4

2 回答 2

2

假设最后三行代码可以这样交换:

for (int i = 1; i < result.Tables.Count - 1; i++) 
    result.Tables[i].Merge(result.Tables[0]);
return result.Tables[0];

资料来源:如何将两个 DataSet 表合并为一个

于 2018-07-12T10:22:19.110 回答
2

当您有一个包含许多工作表的 Excel 工作簿并且您希望在单独的时间使用每个工作表时,我可以建议您使用单例设计模式来存储 Excel 工作簿的信息 - 使用适当的数据/查询模型 - 然后从该单例中读取数据实例。

例如:

// singleton object of 
public class ExcelDataContext
{
    // creating an object of ExcelDataContext
    private static ExcelDataContext instance = new ExcelDataContext();

    // no instantiated available
    private ExcelDataContext()
    {
        FileStream stream = File.Open(filename, FileMode.Open, FileAccess.Read);
        IExcelDataReader excelReader = ExcelReaderFactory.CreateOpenXmlReader(stream);

        DataSet result = excelReader.AsDataSet(new ExcelDataSetConfiguration()
        {
            ConfigureDataTable = (_) => new ExcelDataTableConfiguration()
            {
                UseHeaderRow = true
            }
        });

        this.Sheets = result .Tables;
    }

    // accessing to ExcelDataContext singleton
    public static ExcelDataContext GetInstance()
    {
        return instance;
    }

    // the dataset of Excel
    public DataTableCollection Sheets { get; private set; }
}

然后你可以像这样使用 Excel 工作表:

DataTable sheet1 = ExcelDataContext.GetInstance().Sheets["sheet1"];

当您需要读取另一张纸的数据时:

DataTable otherSheet = ExcelDataContext.GetInstance().Sheets["otherSheet"];

那将不会再次读取 Excel 工作簿。

于 2018-08-14T11:28:10.200 回答