EasyExcelGenerator 1.0.3
The package was renamed in the early stages to also make clear the package supports easy import Excel too. This package is not developed anymore. Please use the ExcelWizard package instead.
dotnet add package EasyExcelGenerator --version 1.0.3
NuGet\Install-Package EasyExcelGenerator -Version 1.0.3
<PackageReference Include="EasyExcelGenerator" Version="1.0.3" />
paket add EasyExcelGenerator --version 1.0.3
#r "nuget: EasyExcelGenerator, 1.0.3"
// Install EasyExcelGenerator as a Cake Addin #addin nuget:?package=EasyExcelGenerator&version=1.0.3 // Install EasyExcelGenerator as a Cake Tool #tool nuget:?package=EasyExcelGenerator&version=1.0.3
EasyExcelGenerator
Easily generate Excel file based on a C# model dynamically in a very simple and straightforward way. In addition, make the generated Excel file directly downloadable from Browser without any hassle in case of using Blazor application. The package is a wrapper for ClosedXML and BlazorFileDownload packages.
How to Use
1- Install EasyExcelGenerator
pacakge from nuget package manager.
2- Register EasyExcelGenerator Service in your application (API or Blazor) by using the AddEasyExcelServices extension.
// Has a `isBlazorApp` argument (default is `false`). In case of using in Blazor application
// For Blazor, pass the true value to register necessary services.
// Has an optional argument for ServiceLifeTime. The default lifetime is Scoped.
builder.Services.AddEasyExcelServices(isBlazorApp: false);
3- Inject IEasyExcelService
into your class and enjoy it!
How much is it simple to generate/download Excel with EasyExcelGenerator?
Assuming you have a collection of a model e.g. var users = List<User>()
which you normally get it from a database and show them in a Grid or something. Now,
you decided to have a live Excel report from it anytime you want.
<img src="https://github.com/farshaddavoudi/EasyExcelGenerator/blob/main/screenshots/Screenshot-5.png">
The Model:
// The model you want to have Excel report upon it
public class User
{
public int Id { get; set; }
public string? FullName { get; set; }
public string? PersonnelCode { get; set; }
public string? Nationality { get; set; }
}
In your Service or Controller:
public class UserController : ControllerBase
{
// Inject the IEasyExcelService Service
private IEasyExcelService _easyExcelService;
public ExcelController(IEasyExcelService easyExcelService)
{
_easyExcelService = easyExcelService;
}
[HttpGet("export-users")]
public IActionResult ExportUsersToExcel()
{
// The below data normally comes from your database
// Show static for demo purposes
var myUsers = new List<User>
{
new() { Id = 1, FullName = "Ronaldo", PersonnelCode = "980923", Nationality = "Portugal" },
new() { Id = 2, FullName = "Messi", PersonnelCode = "991126", Nationality = "Argentine" },
new() { Id = 3, FullName = "Mbappe", PersonnelCode = "991213", Nationality = "France" }
};
// Below will create Excel file as byte[] data
// Just passing your data to method argument and let the rest to the package! hoorya!
// This method has an optional parameter `generatedFileName` which is obvious by the name
GeneratedExcelFile generatedExcelFile = _easyExcelService.GenerateGridLayoutExcel(myUsers);
// Below will create Excel file in specified path and return the full path as string
// The last param is generated file name
string fullPathAsString = _easyExcelService.GenerateGridLayoutExcel(myUsers, @"C:\GeneratedExcelSamples", "Users-Excel");
return Ok(generatedExcelFile);
}
}
In case you are coding in the Blazor application, the scenario is even simpler. Only get the raw data (=myUsers
) from API and use the BlazorDownloadGridLayoutExcel
method
of EasyExcelService
, the Excel file will be instantly downloaded (by opening the download popup) from the browser without any struggle for byte[] handling or something 😃
In IndexPage.razor:
<button @onclick="DownloadExcelReport"> Export Excel </button>
@code {
// Inject the Service
[Inject] private IEasyExcelService EasyExcelService { get; set; } = default!;
private async Task<DownloadFileResult> DownloadExcelReport()
{
// Get your data from API usually by Http call
var myUsers = await apiService.GetMyUsers();
// Just pass the data to method and you are good to go ;)
// This method has an optional parameter `generatedFileName` which is obvious by the name
return EasyExcelService.BlazorDownloadGridLayoutExcel(myUsers);
}
}
Concepts
The Excel you want can be two types:
1- Grid-layout like data; meaning you have a list of data (again like myUsers
) and you want to easily export it to Excel. The Excel would be
relatively simple, having a table-like layout, a header, and data. The first examples in the doc were from this type.
<img src="https://github.com/farshaddavoudi/EasyExcelGenerator/blob/main/screenshots/Screenshot-3.png">
2- Compound Excel; a little more complex than the previous Grid-layout one. This Excel type can include some different Rows, Tables, and special Cells each placed
in different Excel locations. The first type is easier and most straightforward and this type has a different Excel build scenario (Using GenerateCompoundExcel
method of IEasyExcelService
).
<img src="https://github.com/farshaddavoudi/EasyExcelGenerator/blob/main/screenshots/Screenshot-4.png">
Also, you can have a different scenario in saving/retrieving generated Excel files:
1- Get the byte[] of the Excel file and use it for your use case, e.g. sending to another client to be shown or saving in a database, etc.
2- Save the Excel directly on disk and get the full path address to send to the app client or save it in the database.
3- (Blazor app) Normally you want to show the Excel to the user as exported file and do not want to save it somewhere. If your app client is
something other than Blazor (e.g. React, Angular, or MVC), your only choice is to work with generated Excel byte[] data and handle it for
the result you want, but for Blazor apps the story is very simple. Just use the BlazorDownloadGridLayoutExcel
and BlazorDownloadCompoundExcel
methods
from IEasyExcelService
in some click event and the Excel file will be generated and instantly downloaded (by opening the download popup) right from
the browser. Easy-peasy, huh! 😃
Knowing these simple concepts, you will easily understand the IEasyExcelService methods and will be able to generate your favorable Excel in a very easy and fast way.
IEasyExcelService Methods:
public interface IEasyExcelService
{
// Generate Simple Grid Excel file from special model configured options with EasyExcel attributes
public GeneratedExcelFile GenerateGridLayoutExcel(GridLayoutExcelBuilder multiSheetsGridLayoutExcelBuilder);
// Generate Simple Single Sheet Grid Excel file from special model configured options with EasyExcel attributes
public GeneratedExcelFile GenerateGridLayoutExcel(object singleSheetDataList, string? generatedFileName = null);
// Generate Grid-Layout Excel having multiple Sheets from special model configured options with EasyExcel attributes
public string GenerateGridLayoutExcel(GridLayoutExcelBuilder multiSheetsGridLayoutExcelBuilder, string savePath);
// Generate Simple Single Sheet Grid Excel file from special model configured options with EasyExcel attributes
public string GenerateGridLayoutExcel(object singleSheetDataList, string savePath, string generatedFileName);
// Generate Compound Excel consisting multiple parts like some Rows, Tables, Special Cells, etc each in different Excel Location
public GeneratedExcelFile GenerateCompoundExcel(CompoundExcelBuilder compoundExcelBuilder);
// Generate Excel file and save it in path and return the saved url
public string GenerateCompoundExcel(CompoundExcelBuilder compoundExcelBuilder, string savePath);
#region Blazor Application
// [Blazor only] Generate and Download instantly from Browser the Simple Multiple Sheet Grid Excel file from special model configured options with EasyExcel attributes in Blazor apps
public Task<DownloadFileResult> BlazorDownloadGridLayoutExcel(GridLayoutExcelBuilder multiSheetsGridLayoutExcelBuilder);
// [Blazor only] Generate and Download instantly from Browser the Simple Single Sheet Grid Excel file from special model configured options with EasyExcel attributes in Blazor apps
public Task<DownloadFileResult> BlazorDownloadGridLayoutExcel(object singleSheetDataList, string? generatedFileName = null);
// [Blazor only] Generate and Download instantly from Browser the Compound Excel consisting multiple parts like some Rows, Tables, Special Cells, etc each in different Excel Location in Blazor apps
public Task<DownloadFileResult> BlazorDownloadCompoundExcel(CompoundExcelBuilder compoundExcelBuilder);
#endregion
}
Generate Single Sheet Grid-Layout Excel
For single sheet Grid-layout Excel, it is as easy as passing the data (collection of a model like var myUsers = new List<User>();
, remember?)
to the GenerateGridLayoutExcel
method (or BlazorDownloadGridLayoutExcel
in the case of the Blazor app). It will generate (download in Blazor) a very
simple Excel filled with data without any Excel customization.
<img src="https://github.com/farshaddavoudi/EasyExcelGenerator/blob/main/screenshots/Screenshot-5.png">
You see the example in how much is it simple section.
What if you want some customization for the generated Excel file?
For example, having some aligns for header or cells, text font/size/color, different background color for header or cells or a specific column!,
custom header name for a column, custom header height or column width or Sheet direction (RTL/LTR), etc..? All these options plus a lot more can be configured by two
attributes you can use on your model. [ExcelSheet]
for Excel generic properties and [ExcelColumn]
for per property (column) customization.
Remember the User model, we can use the attributes below to customize our Users Excel:
[ExcelSheet(SheetName = "MyUsers", DefaultTextAlign = TextAlign.Center, HeaderBackgroundColor = KnownColor.LightBlue, HeaderHeight = 40,
BorderType = LineStyle.DashDotDot, DataBackgroundColor = KnownColor.Bisque, DataRowHeight = 25, IsSheetLocked = true,
SheetDirection = SheetDirection.RightToLeft, FontColor = KnownColor.Red)]
public class User
{
[ExcelColumn(HeaderName = "UserId", HeaderTextAlign = TextAlign.Right, DataTextAlign = TextAlign.Right, FontColor = KnownColor.Blue)]
public int Id { get; set; }
[ExcelColumn(HeaderName = "Name", HeaderTextAlign = TextAlign.Left, FontWeight = FontWeight.Bold)]
public string? FullName { get; set; }
[ExcelColumn(HeaderName = "Personnel No", HeaderTextAlign = TextAlign.Left, ColumnWidth = 50, FontSize = 15)]
public string? PersonnelCode { get; set; }
public string? Nationality { get; set; }
}
The Result: <img src="https://github.com/farshaddavoudi/EasyExcelGenerator/blob/main/screenshots/Screenshot-2.png">
You do not need to remember all the properties. Just use the attribute and intellisense will show you all the available options you can use to customize Excel.
Generate Multiple Sheets Grid-Layout Excel
It is almost the same with a single sheet, using the same GenerateGridLayoutExcel
method (BlazorDownloadGridLayoutExcel
method in case of the Blazor app) with the GridLayoutExcelBuilder
argument
that should be provided to configure the Excel file. The customization
is exactly like Single sheet Grid-layout Excel (See the previous section).
Generate Compound Excel
Using the GenerateCompoundExcel
method (BlazorDownloadCompoundExcel
in case of Blazor application) you can create any customized Excel file. Just
go along with the CompoundExcelBuilder
argument and provide the necessary parts for your Excel.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.1 is compatible. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.1
- BlazorDownloadFile (>= 2.3.1.1)
- ClosedXML (>= 0.95.4)
- ClosedXML.Report (>= 0.2.4)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.