WorksheetInfo.cs 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. using ClosedXML.Excel;
  2. namespace ExcelInfo
  3. {
  4. public class WorksheetInfo
  5. {
  6. private static XLDataType EstablishType(IXLCells? cells)
  7. {
  8. if (cells == null || !cells.Any())
  9. return XLDataType.Error;
  10. var numberOfCells = cells.Count();
  11. return numberOfCells > 2 ? cells.Last().DataType : cells.First().DataType;
  12. }
  13. public static List<WorksheetRecord> GetInfoOnWorksheets(string workbookPath)
  14. {
  15. var workbook = new XLWorkbook(workbookPath);
  16. return GetInfoOnWorksheets(workbook);
  17. }
  18. private static List<WorksheetRecord> GetInfoOnWorksheets(IXLWorkbook workbook)
  19. {
  20. var worksheets = new List<WorksheetRecord>();
  21. foreach (var sheet in workbook.Worksheets)
  22. {
  23. var columns = new List<ColumnInfo>();
  24. var firstRow = sheet.FirstRowUsed();
  25. foreach (var cell in firstRow.CellsUsed())
  26. {
  27. var columnCells = cell.WorksheetColumn().CellsUsed();
  28. var cellsType = EstablishType(columnCells);
  29. columns.Add(new ColumnInfo(cell.Address.ColumnLetter, cell.Value.ToString(), columnCells.Count() - 1, cellsType, cell.Address.ColumnNumber));
  30. }
  31. worksheets.Add(new WorksheetRecord(sheet.Position, sheet.Name, columns));
  32. }
  33. return worksheets;
  34. }
  35. }
  36. }