AutoOpenXml 2.0.3
dotnet add package AutoOpenXml --version 2.0.3
NuGet\Install-Package AutoOpenXml -Version 2.0.3
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="AutoOpenXml" Version="2.0.3" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add AutoOpenXml --version 2.0.3
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: AutoOpenXml, 2.0.3"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install AutoOpenXml as a Cake Addin #addin nuget:?package=AutoOpenXml&version=2.0.3 // Install AutoOpenXml as a Cake Tool #tool nuget:?package=AutoOpenXml&version=2.0.3
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
AutoOpenXML
https://github.com/RuanVFachini/AutoOpenXML
1 Why does this lib exist?
Using C# attributes annotations 'AutoOpenXML' was created to smooth the exportation and importation process of object collections to the worksheet, providing the correct formats without great cost of implementation.
2 How to use
2.1 Class example:
<code>
[ExportWorkSheet(Variables.WorksheetName)]
internal class ModelDateTimeProperty
{
public string Name { get; set; }
[ExportColumn(Variables.FieldName, 1)]
public DateTime BirthDay { get; set; }
public ModelDateTimeProperty() { }
public ModelDateTimeProperty(string name, DateTime birthDay)
{
Name = name;
BirthDay = birthDay;
}
}
</code>
2.2 Attributres syntax:
2.2.1 Class Attributres:
<code>
[ExportWorkSheet(
{worksheetname : string}
{ClosedXml.XLTableTheme.Name : string}
)]
</code>
2.2.2 Property Attributres:
2.2.2.1 To Export Column:
<code>
[ExportColumn(
{propertyLabel : string},
{columnIndex : int},
{numberFormat : string}
)]
</code>
2.2.2.2 Header Column Background:
<code>
[ExportColumnHeaderBackgoundColor(
{red: int},
{green: int},
{blue: int})]
</code>
2.3 Suported Types:
-string
-int
-bool
-long
-decimal
-long
-DateTime
-int?
-long?
-bool?
-decimal?
-long?
-DateTime?
3 Example
3.1 Model Class Exemple:
<code>
[ExportWorkSheet("WorksheetName")]
public class ModelOrderedProperties
{
[ExportColumn("Code", 2, "00000")]
[ExportColumnHeaderBackgoundColor(0, 255, 0)]
public int Id { get; set; }
[ExportColumn("Name", 1)]
public string Name { get; set; }
[ExportColumn("Height", 4)]
public decimal Height { get; set; }
[ExportColumn("BirthDateLabel", 3)]
public DateTime BrithDate { get; set; }
public ModelOrderedProperties() { }
public ModelOrderedProperties(
int id,
string name,
decimal height,
DateTime brithDate)
{
Id = id;
Name = name;
Height = height;
BrithDate = brithDate;
}
}
</code>
3.1 Export Class Exemple:
3.1.1 Export Once Worksheet:
<code>
var stream = new ExportManagerBuilder<ModelOrderedProperties>()
.Init()
.SetData(Data.ToList())
.StartExportProcess();
var workbook = new XLWorkbook(stream);
</code>
3.1.2 Export Many Worksheet:
<code>
var stream = new MultiExportManagerBuilder()
.Init()
.SetData(VariablesModelDateTimeProperty.Data)
.SetData(VariablesModelDecimalProperty.Data)
.StartExportProcess();
var workbook = new XLWorkbook(stream);
</code>
3.2 Import Class Exemple:
<code>
var result = new ImportManagerBuilder<ModelDateTimeProperty>()
.OpenFile(StreamTestFile.GetStreamTestFile(), "Planilha1")
.Init()
.StartImportProcess();
</code>
4 Obs.:
- DateTime properties will be exported like DateTime Excel column format. For importation the same column type is required.
5 Release notes:
2.0.x
2.0.1
- Adjust To Content [Fix]
2.0.2
- Formula import support [Feat]
2.0.3
- Import: not string fields: cast to string failure [Fix]
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. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- ClosedXML (>= 0.95.4)
- fasterflect.reflect (>= 3.1.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.