Как пройти тестовые данные используя имя тестового примера - PullRequest
0 голосов
/ 09 апреля 2019

Я хочу получить тестовые данные, используя имя тестового набора и все тестовые данные тестовых случаев в одном листе. Но в моем коде я хочу дать номер строки и имя столбца для всех данных тестового примера. Ниже я вставляю свой код .

пространство имен SeleniumBL { открытый класс ExcelLibrary { public static System.Collections.Specialized.NameValueCollection AppSettings {get; } статическая строка fileName = ConfigurationSettings.AppSettings ["ExcelPath"];

    private static DataTable ExcelToDataTable(string fileName, string excelSheet)
    {
        //open file and returns as Stream
        FileStream stream = File.Open(fileName, FileMode.Open, FileAccess.Read);
        //Createopenxmlreader via ExcelReaderFactory
        IExcelDataReader excelReader = ExcelReaderFactory.CreateOpenXmlReader(stream); //.xlsx
                                                                                       //Set the First Row as Column Name
        excelReader.IsFirstRowAsColumnNames = true;
        //Return as DataSet
        DataSet result = excelReader.AsDataSet();
        //Get all the Tables
        DataTableCollection table = result.Tables;
        //Store it in DataTable
        DataTable resultTable = table[excelSheet];

        //return
        return resultTable;
    }

    static List<Datacollection> dataCol = new List<Datacollection>();

    public static void PopulateInCollection(string excelSheet)
    {
        if (!dataCol.Any(x => x.excelSheet == excelSheet))
        {
            DataTable table = ExcelToDataTable(fileName, excelSheet);

            //Iterate through the rows and columns of the Table
            for (int row = 1; row <= table.Rows.Count; row++)
            {
                for (int col = 0; col < table.Columns.Count; col++)
                {
                    Datacollection dtTable = new Datacollection()
                    {
                        excelSheet = excelSheet,
                        rowNumber = row,
                        colName = table.Columns[col].ColumnName,
                        colValue = table.Rows[row - 1][col].ToString()
                    };
                    //Add all the details for each row
                    dataCol.Add(dtTable);
                }
            }
        }
    }

    public static string ReadData(int rowNumber, string columnName)
    {
        try
        {
            //var dataabc = (from colData in dataCol
            //               where colData.colName == columnName && colData.rowNumber == rowNumber
            //               select colData.colValue).ToList();

            //Retriving Data using LINQ to reduce much of iterations
            string data = (from colData in dataCol
                           where colData.colName == columnName && colData.rowNumber == rowNumber
                           select colData.colValue).SingleOrDefault();

            return data.ToString();
        }
        catch (Exception e)
        {
            return null;
        }
    }


}

public class Datacollection
{
    public string excelSheet { get; set; }
    public int rowNumber { get; set; }
    public string colName { get; set; }
    public string colValue { get; set; }
}

}

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...