2023-09-29 16:48:59 +05:00
|
|
|
|
using ClosedXML.Excel;
|
|
|
|
|
using System;
|
|
|
|
|
using System.IO;
|
2024-02-07 09:40:00 +05:00
|
|
|
|
using System.Linq;
|
2023-09-29 16:48:59 +05:00
|
|
|
|
|
|
|
|
|
namespace AsbCloudInfrastructure;
|
|
|
|
|
|
2024-02-07 09:40:00 +05:00
|
|
|
|
public static class XLExtentions
|
2023-09-29 16:48:59 +05:00
|
|
|
|
{
|
2024-02-13 16:05:16 +05:00
|
|
|
|
public const string ProblemDetailsTemplate = "Лист: {0}, Строка: {1}, Столбец: {2}. {3}";
|
|
|
|
|
public const string NotFoundSheetTemplate = "Книга excel не содержит листа {0}";
|
|
|
|
|
public const string InvalidValueTemplate = "Лист: {0}, Строка: {1}, Столбец: {2}. Содержит некорректное значение";
|
|
|
|
|
|
2024-02-07 09:40:00 +05:00
|
|
|
|
public static IXLWorksheet GetWorksheet(this IXLWorkbook workbook, string sheetName) =>
|
|
|
|
|
workbook.Worksheets.FirstOrDefault(ws => string.Equals(ws.Name.Trim(), sheetName.Trim(), StringComparison.CurrentCultureIgnoreCase))
|
2024-02-13 16:05:16 +05:00
|
|
|
|
?? throw new FileFormatException(string.Format(NotFoundSheetTemplate, sheetName));
|
2024-02-07 09:40:00 +05:00
|
|
|
|
|
2024-02-16 15:21:01 +05:00
|
|
|
|
public static IXLCell SetCellValue<T>(this IXLCell cell, T value, string? format = null)
|
2024-02-16 12:02:54 +05:00
|
|
|
|
{
|
|
|
|
|
if (typeof(T) == typeof(DateTime))
|
2024-02-16 15:21:01 +05:00
|
|
|
|
{
|
|
|
|
|
cell.Style.DateFormat.Format = format ?? "DD.MM.YYYY HH:MM:SS";
|
|
|
|
|
}
|
2024-02-16 12:02:54 +05:00
|
|
|
|
|
|
|
|
|
cell.Value = XLCellValue.FromObject(value);
|
|
|
|
|
|
|
|
|
|
return cell;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static IXLCell SetHyperlink(this IXLCell cell, string link)
|
2024-02-16 15:21:01 +05:00
|
|
|
|
{
|
|
|
|
|
cell.SetHyperlink(new XLHyperlink(link));
|
|
|
|
|
|
|
|
|
|
return cell;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static T? GetCellValue<T>(this IXLCell cell)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
if (cell.IsEmpty() && default(T) == null)
|
|
|
|
|
return default;
|
|
|
|
|
|
2024-02-07 09:40:00 +05:00
|
|
|
|
return cell.GetValue<T>();
|
|
|
|
|
}
|
|
|
|
|
catch
|
|
|
|
|
{
|
2024-02-13 16:05:16 +05:00
|
|
|
|
var message = string.Format(InvalidValueTemplate, cell.Worksheet.Name, cell.Address.RowNumber, cell.Address.ColumnNumber);
|
2024-02-08 14:50:14 +05:00
|
|
|
|
throw new FileFormatException(message);
|
2024-02-07 09:40:00 +05:00
|
|
|
|
}
|
|
|
|
|
}
|
2023-09-29 16:48:59 +05:00
|
|
|
|
}
|