Skip to content

.NET Utility classes for the DocumentFormat.OpenXml library. Easily create Excel spreadsheets.

License

Notifications You must be signed in to change notification settings

leandroaraujo/openxmlutils

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OpenXMLUtils

Utility classes for the Open XML SDK 2.5 for Office.

Copyright (c) Geoplex All rights reserved. Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.

Package

https://www.nuget.org/packages/OpenXmlUtils/

Documentation

Currently supports creation of simple spreadsheets from a collection of objects based on this: http://www.codeproject.com/Articles/97307/Using-C-and-Open-XML-SDK-for-Microsoft-Office.

##Example Usage

Using a list of objects:

var songs =
new List<Song>
	{ new Song { Artist = "Joy Devision", Title = "Disorder", Date = DateTime.Today, TimeSpan = TimeSpan.FromSeconds(3343), Int = 89453312L, Double = 4043.4545, Bool = false },
	  new Song { Artist = "Moderate", Title = "A New Error", Date = DateTime.Today, TimeSpan = TimeSpan.FromSeconds(34345), Int = 89563312L, Double = 5.6, Bool = true },
	  new Song { Artist = "Massive Attack", Title = "Paradise Circus", Date = DateTime.Today + TimeSpan.FromDays(53), TimeSpan = TimeSpan.FromSeconds(545), Int = 344334L, Double = 222.3, Bool = false },
	  new Song { Artist = "The Horrors", Title = "Still Life", Date = DateTime.Today - TimeSpan.FromDays(1), TimeSpan = TimeSpan.FromSeconds(22345), Int = 9497934L, Double = 33.4634444, Bool = true },
	  new Song { Artist = "Todd Terje", Title = "Inspector Norse", Date = DateTime.Today - TimeSpan.FromDays(356), TimeSpan = TimeSpan.FromSeconds(5565), Int = 34211343L, Double = 54.44444, Bool = false },
	  new Song { Artist = "Alpine", Title = "Hands", Date = DateTime.Today - TimeSpan.FromDays(5.5), TimeSpan = TimeSpan.FromSeconds(9907), Int = 32323333L, Double = 3445.44, Bool = false },
	  new Song { Artist = "Parquet Courts", Title = "Ducking and Dodging", Date = DateTime.Today - TimeSpan.FromDays(88.55), TimeSpan = TimeSpan.FromSeconds(8877), Int = 8088872L, Double = 44.0, Bool = false },        
	};

var fields = new List<SpreadsheetField>
{
	new SpreadsheetField{ Title = "Artist", FieldName = "Artist"},
	new SpreadsheetField{ Title = "Title", FieldName = "Title"},
	new SpreadsheetField{ Title = "RandomDate", FieldName = "Date"},
	new SpreadsheetField{ Title = "RandomTimeSpan", FieldName = "TimeSpan"},
	new SpreadsheetField{ Title = "RandomInt", FieldName = "Int"},
	new SpreadsheetField{ Title = "RandomDouble", FieldName = "Double"},
	new SpreadsheetField{ Title = "RandomBool", FieldName = "Bool"}
};

Spreadsheet.Create(@"C:\temp\songs.xlsx",
	new SheetDefinition<Song>
	{
		Fields = fields,
		Name = "Songs",
		SubTitle = DateTime.Today.ToLongDateString(),
		IncludeTotalsRow = true,
		Objects = songs
	});

Using a list of dictionaries:

var songs =
	new List<object>
{
	new Dictionary<string, object> { { "Artist" , "Joy Devision"}, {"Title" , "Disorder"}, {"Date" , DateTime.Today}, {"TimeSpan" , TimeSpan.FromSeconds(3343)}, {"Int" ,89453312L},{ "Double" , 4043.4545}, {"Bool" , false }},
	new Dictionary<string, object> { { "Artist" , "Moderate"}, {"Title" , "A New Error"}, {"Date" , DateTime.Today}, {"TimeSpan" , TimeSpan.FromSeconds(34345)}, {"Int", 89563312L},{ "Double" , 5.6}, {"Bool" , true }},
	new Dictionary<string, object> { { "Artist" , "Massive Attack"}, {"Title" , "Paradise Circus"}, {"Date" , DateTime.Today}, {"TimeSpan" , TimeSpan.FromSeconds(545)}, {"Int", 344334L},{ "Double" , 222.3}, {"Bool" , false }},
	new Dictionary<string, object> { { "Artist" , "The Horrors"}, {"Title" , "Still Life"}, {"Date" , DateTime.Today}, {"TimeSpan" , TimeSpan.FromSeconds(1123)}, {"Int", 9497934L},{ "Double" , 33.4634444}, {"Bool" , true }},
	new Dictionary<string, object> { { "Artist" , "Todd Terje"}, {"Title" , "Inspector Norse"}, {"Date" , DateTime.Today}, {"TimeSpan" , TimeSpan.FromSeconds(9973)}, {"Int", 34211343L},{ "Double" , 54.44444}, {"Bool" , false }},
	new Dictionary<string, object> { { "Artist" , "Alpine"}, {"Title" , "Hands"}, {"Date" , DateTime.Today}, {"TimeSpan" , TimeSpan.FromSeconds(3841)}, {"Int", 32323333L},{ "Double" , 3445.44}, {"Bool" , false }},
	new Dictionary<string, object> { { "Artist" , "Parquet Courts"}, {"Title" , "Ducking and Dodging"}, {"Date" , DateTime.Today}, {"TimeSpan" , TimeSpan.FromSeconds(9973)}, {"Int", 8088872L},{ "Double" , 44.0}, {"Bool" , false }}        
};

var fields = new List<SpreadsheetField>
{
	new SpreadsheetField{ Title = "Artist", FieldName = "Artist"},
	new SpreadsheetField{ Title = "Title", FieldName = "Title"},
	new SpreadsheetField{ Title = "RandomDate", FieldName = "Date"},
	new SpreadsheetField{ Title = "RandomTimeSpan", FieldName = "TimeSpan"},
	new SpreadsheetField{ Title = "RandomInt", FieldName = "Int"},
	new SpreadsheetField{ Title = "RandomDouble", FieldName = "Double"},
	new SpreadsheetField{ Title = "RandomBool", FieldName = "Bool"}
};

Spreadsheet.Create(@"C:\temp\songs_dict.xlsx",
	new SheetDefinition<object>
	{
		Fields = fields,
		Name = "Songs",
		IncludeTotalsRow = true,
		Objects = songs
	});

Creating multiple sheets:

Spreadsheet.Create(@"C:\temp\songs_multi.xlsx",
	new List<SheetDefinition<Song>>
	{
		new SheetDefinition<Song>
		{
			Fields = fields,
			Name = "1",
			IncludeTotalsRow = true,
			Objects = songs
		},
		new SheetDefinition<Song>
		{
			Fields = fields,
			Name = "2",
			IncludeTotalsRow = true,
			Objects = songs2
		}
	});

Hyperlinks:

var songs =
    new List<Song>
        { 
            new Song { Artist = "Parquet Courts", Title = "Ducking and Dodging", Url = "https://parquetcourts.wordpress.com", Hyperlink = "parquetcourts.wordpress.com"}, 
        };

var fields = new List<SpreadsheetField>
{
    new SpreadsheetField{ Title = "Artist", FieldName = "Artist"},
    new SpreadsheetField{ Title = "Title", FieldName = "Title"},
    new HyperlinkField{ Title = "Website", FieldName = "Url", DisplayFieldName = "Hyperlink"}
};

Spreadsheet.Create(@"C:\temp\songs_hyperlinks.xlsx",
    new SheetDefinition<Song>
    {
        Fields = fields,
        Name = "Songs",
        SubTitle = DateTime.Today.ToLongDateString(),
        IncludeTotalsRow = true,
        Objects = songs
    });

Row Grouping:

var songs =
    new List<object>
{
    new Dictionary<string, object> { { "Artist" , "Joy Devision"} },
    new List<object> {
            new Dictionary<string, object> { { "Albumn" , "Closer"} },
            new List<object> {
                new Dictionary<string, object>{ {"Title" , "Isolation"} },
                new Dictionary<string, object>{ {"Title" , "Colony"} },
                new Dictionary<string, object>{ {"Title" , "Decades"} },
            },
            new Dictionary<string, object> { { "Albumn" , "Unknown Pleasures"} },
            new List<object> {
                new Dictionary<string, object>{ {"Title" , "Disorder"} },
                new Dictionary<string, object>{ {"Title" , "Candidate"} },
                new Dictionary<string, object>{ {"Title" , "She's Lost Control"} }
            },
        },
    new Dictionary<string, object> { { "Artist" , "Moderate"} },
    new List<object> {
            new Dictionary<string, object>{ {"Title" , "A New Error"} },
            new Dictionary<string, object>{ {"Title" , "Rusty Nails"} },
            new Dictionary<string, object>{ {"Title" , "Seamonkey"} },
        },
};

var fields = new List<SpreadsheetField>
{
    new SpreadsheetField{ Title = "Artist", FieldName = "Artist"},
    new SpreadsheetField{ Title = "Albumn", FieldName = "Albumn"},
    new SpreadsheetField{ Title = "Title", FieldName = "Title"},
};

Spreadsheet.Create(@"C:\temp\songs_row_grouping.xlsx",
    new SheetDefinition<object>
    {
        Fields = fields,
        Name = "Songs",
        IncludeTotalsRow = false,
        Objects = songs
    });

About

.NET Utility classes for the DocumentFormat.OpenXml library. Easily create Excel spreadsheets.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C# 100.0%