Reo.Core.Report.ClosedXml
10.0.249
dotnet add package Reo.Core.Report.ClosedXml --version 10.0.249
NuGet\Install-Package Reo.Core.Report.ClosedXml -Version 10.0.249
<PackageReference Include="Reo.Core.Report.ClosedXml" Version="10.0.249" />
<PackageVersion Include="Reo.Core.Report.ClosedXml" Version="10.0.249" />Directory.Packages.props
<PackageReference Include="Reo.Core.Report.ClosedXml" />Project file
paket add Reo.Core.Report.ClosedXml --version 10.0.249
#r "nuget: Reo.Core.Report.ClosedXml, 10.0.249"
#:package Reo.Core.Report.ClosedXml@10.0.249
#addin nuget:?package=Reo.Core.Report.ClosedXml&version=10.0.249Install as a Cake Addin
#tool nuget:?package=Reo.Core.Report.ClosedXml&version=10.0.249Install as a Cake Tool
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 (>= 202620)
- Microsoft.AspNetCore.Mvc.NewtonsoftJson (>= 10.0.9)
- Microsoft.Bcl.AsyncInterfaces (>= 10.0.9)
- Microsoft.Extensions.Configuration (>= 10.0.9)
- Microsoft.Extensions.Configuration.Abstractions (>= 10.0.9)
- Microsoft.Extensions.Configuration.Binder (>= 10.0.9)
- Microsoft.Extensions.DependencyInjection (>= 10.0.9)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.9)
- Microsoft.Extensions.FileProviders.Embedded (>= 10.0.9)
- Microsoft.Extensions.Hosting.Abstractions (>= 10.0.9)
- Microsoft.Extensions.Http.Polly (>= 10.0.9)
- Microsoft.Extensions.Logging (>= 10.0.9)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.9)
- Microsoft.Extensions.Options (>= 10.0.9)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 10.0.9)
- Newtonsoft.Json (>= 13.0.4)
- Polly (>= 8.5.0)
- RedLock.net (>= 2.3.2)
- Reo.Core.Hosting (>= 10.0.249)
- Reo.Models.StronglyTyped (>= 1.0.35)
- stbychkov.AutoLoggerMessage (>= 1.0.15)
- Swashbuckle.AspNetCore (>= 10.2.3)
- System.Configuration.ConfigurationManager (>= 10.0.9)
- 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.249 | 0 | 7/2/2026 |
| 10.0.248 | 9 | 7/2/2026 |
| 10.0.247 | 42 | 7/1/2026 |
| 10.0.246 | 58 | 7/1/2026 |
| 10.0.245 | 65 | 7/1/2026 |
| 10.0.244 | 63 | 7/1/2026 |
| 10.0.243 | 73 | 6/30/2026 |
| 10.0.242 | 82 | 6/30/2026 |
| 10.0.239 | 90 | 6/30/2026 |
| 10.0.238 | 81 | 6/30/2026 |
| 10.0.237 | 78 | 6/30/2026 |
| 10.0.236 | 87 | 6/29/2026 |
| 10.0.235 | 94 | 6/29/2026 |
| 10.0.234 | 93 | 6/29/2026 |
| 10.0.233 | 89 | 6/26/2026 |
| 10.0.232 | 89 | 6/26/2026 |
| 10.0.231 | 93 | 6/26/2026 |
| 10.0.230 | 97 | 6/26/2026 |
| 10.0.229 | 90 | 6/25/2026 |
| 10.0.228 | 94 | 6/25/2026 |