Reo.Core.Report.ClosedXml
10.0.119
dotnet add package Reo.Core.Report.ClosedXml --version 10.0.119
NuGet\Install-Package Reo.Core.Report.ClosedXml -Version 10.0.119
<PackageReference Include="Reo.Core.Report.ClosedXml" Version="10.0.119" />
<PackageVersion Include="Reo.Core.Report.ClosedXml" Version="10.0.119" />
<PackageReference Include="Reo.Core.Report.ClosedXml" />
paket add Reo.Core.Report.ClosedXml --version 10.0.119
#r "nuget: Reo.Core.Report.ClosedXml, 10.0.119"
#:package Reo.Core.Report.ClosedXml@10.0.119
#addin nuget:?package=Reo.Core.Report.ClosedXml&version=10.0.119
#tool nuget:?package=Reo.Core.Report.ClosedXml&version=10.0.119
Reo.Core.Report.ClosedXml
Описание пакета
Пакет Reo.Core.Report.ClosedXml предоставляет функционал для генерации отчётов в формате Excel (XLSX) с использованием библиотеки ClosedXML.Report. Он позволяет создавать динамические отчёты на основе шаблонов, применять фильтры данных и работать с метаданными отчётов.
Решаемые задачи:
- Генерация Excel-отчётов на основе шаблонов.
- Поддержка фильтрации данных для отчётов.
- Управление метаданными (например, имя файла, байты отчёта, данные).
- Интеграция с контейнером зависимостей (DI) через
Microsoft.Extensions.DependencyInjection.
Основные компоненты
ReportDataFilterБазовый класс для фильтрации данных, используемый в интерфейсеIClosedXmlReportCreator.ClosedXmlReportMetadata<TData>Класс, содержащий метаданные отчёта: имя файла, массив байтов Excel-файла и данные отчёта (TData).IClosedXmlReportCreator<TData, TFilter>Интерфейс для создания отчётов. Требует реализации методаCreateAsync, который возвращаетClosedXmlReportMetadata<TData>.BaseXlsxClosedXmlReportCreator<TData, TFilter>Абстрактный базовый класс, реализующийIClosedXmlReportCreator. Обеспечивает загрузку шаблонов, подготовку данных и сохранение отчёта в поток.ServiceCollectionExtensionsМетоды расширения для регистрации сервисов в DI-контейнере. Используется для автоматической регистрации всехIClosedXmlReportCreator<,>в сборке.
Требования
- .NET: Совместим с версиями .NET 8.0 и .NET 9.0.
- Зависимости:
- ClosedXML (библиотека для работы с Excel).
System.IO,System.Threading,System.Threading.Tasks(стандартные библиотеки .NET).
Установка
Используйте следующие команды для установки пакета:
# через NuGet Package Manager
Install-Package Reo.Core.Report.ClosedXml
# через .NET CLI
dotnet add package Reo.Core.Report.ClosedXml
Настройка
Регистрация сервисов в DI
В ASP.NET Core или любом проекте с DI, зарегистрируйте сервисы следующим образом:
services.AddReoClosedXmlDataImport<YourAssembly>();
Замените YourAssembly на сборку, содержащую реализации IClosedXmlReportCreator<,>.
Конфигурационные параметры
- Путь к шаблону (
PathToTemplate): Указывается в производном классеBaseXlsxClosedXmlReportCreator. - Имя выходного файла (
OutputFileName): Также определяется в производном классе. - Запасной шрифт (
FallbackFont): По умолчанию"Courier New".
Использование
Пример реализации
public class MyReportFilter : ReportDataFilter
{
public string FilterValue { get; set; }
}
public class MyReportData
{
public string Title { get; set; }
public int Count { get; set; }
}
public class MyReportCreator : BaseXlsxClosedXmlReportCreator<MyReportData, MyReportFilter>
{
protected override string PathToTemplate => "Templates/MyReportTemplate.xlsx";
protected override string OutputFileName => "MyReport.xlsx";
protected override async Task<MyReportData> PrepareDataAsync(MyReportFilter filter, CancellationToken token)
{
return new MyReportData
{
Title = "Отчёт за " + filter.FilterValue,
Count = 42
};
}
}
Использование в приложении
var creator = new MyReportCreator();
var metadata = await creator.CreateAsync(new MyReportFilter { FilterValue = "2025" }, CancellationToken.None);
Лицензия
Данный пакет распространяется под лицензией MIT.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net10.0
- ClosedXML (>= 0.105.0)
- ClosedXML.Report (>= 0.2.12)
- DocumentFormat.OpenXml (>= 3.5.1)
- FluentValidation (>= 12.1.1)
- FluentValidation.AspNetCore (>= 11.3.1)
- Flurl (>= 4.0.0)
- Flurl.Http (>= 4.0.2)
- JetBrains.Annotations (>= 2025.2.4)
- Microsoft.AspNetCore.Mvc.NewtonsoftJson (>= 10.0.7)
- Microsoft.Bcl.AsyncInterfaces (>= 10.0.7)
- Microsoft.Extensions.Configuration (>= 10.0.7)
- Microsoft.Extensions.Configuration.Abstractions (>= 10.0.7)
- Microsoft.Extensions.Configuration.Binder (>= 10.0.7)
- Microsoft.Extensions.DependencyInjection (>= 10.0.7)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.7)
- Microsoft.Extensions.FileProviders.Embedded (>= 10.0.7)
- Microsoft.Extensions.Http.Polly (>= 10.0.7)
- Microsoft.Extensions.Logging (>= 10.0.7)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.7)
- Microsoft.Extensions.Options (>= 10.0.7)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 10.0.7)
- Newtonsoft.Json (>= 13.0.4)
- Polly (>= 8.5.0)
- RedLock.net (>= 2.3.2)
- Reo.Core.Hosting (>= 10.0.119)
- stbychkov.AutoLoggerMessage (>= 1.0.15)
- System.Configuration.ConfigurationManager (>= 10.0.7)
- System.Linq.Async (>= 7.0.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 10.0.119 | 0 | 4/23/2026 |
| 10.0.117 | 0 | 4/23/2026 |
| 10.0.116 | 37 | 4/22/2026 |
| 10.0.115 | 39 | 4/22/2026 |
| 10.0.114 | 76 | 4/21/2026 |
| 10.0.113 | 81 | 4/21/2026 |
| 10.0.112 | 89 | 4/17/2026 |
| 10.0.111 | 85 | 4/16/2026 |
| 10.0.110 | 91 | 4/16/2026 |
| 10.0.109 | 88 | 4/16/2026 |
| 10.0.108 | 78 | 4/16/2026 |
| 10.0.107 | 84 | 4/16/2026 |
| 10.0.106 | 90 | 4/16/2026 |
| 10.0.105 | 87 | 4/15/2026 |
| 10.0.104 | 93 | 4/15/2026 |
| 10.0.103 | 86 | 4/14/2026 |
| 10.0.101 | 91 | 4/14/2026 |
| 10.0.100 | 93 | 4/13/2026 |
| 10.0.99 | 83 | 4/13/2026 |
| 10.0.98 | 96 | 4/13/2026 |