SpreadsheetDocument
Nuget - DocumentFormat.OpenXml
The SDK is built on the System.IO.Packaging API and provides strongly types classes to manipulate documents that adhere to the Office Open XML file format.
The SDK supports .NET 3.5 and .NET Core 2.0.
link - ericwhite.com/blog/introduction-to-open-xml-series
DocumentFormat.OpenXml.Packaging.SpreadsheetDocument
DocumentFormat.OpenXml.Packaging.WorkbookPart
DocumentFormat.OpenXml.Packaging.WorksheetPart
DocumentFormat.OpenXml.Packaging.Worksheet
DocumentFormat.OpenXml.Packaging.Row
DocumentFormat.OpenXml.Packaging.Cell
DocumentFormat.OpenXml.Packaging.SheetData
DocumentFormat.OpenXml.Office2010.CustomUI
DocumentFormat.OpenXml.Office2010.Excel
DocumentFormat.OpenXml.Office2013.Excel
Create a new Workbook with one worksheet
using DocumentFormat.OpenXml;
using DocumentFormat.OpenXml.Packaging;
using DocumentFormat.OpenXml.Spreadsheet;
static void CreateSpreadsheetWorkbook(string filepath)
{
SpreadsheetDocument spreadsheetDocument = SpreadsheetDocument.Create(filepath, SpreadsheetDocumentType.Workbook);
WorkbookPart workbookPart = spreadsheetDocument.AddWorkbookPart();
workbookPart.Workbook = new Workbook();
WorksheetPart worksheetPart = workbookPart.AddNewPart<WorksheetPart>();
worksheetPart.Worksheet = new Worksheet(new SheetData());
Sheets sheets = workbookPart.Workbook.AppendChild(new Sheets());
Sheet sheet = new Sheet() { Id = workbookPart.GetIdOfPart(worksheetPart), SheetId = 1, Name = "mySheet" };
sheets.Append(sheet);
workbookPart.Workbook.Save();
spreadsheetDocument.Dispose();
}
Opens an Existing Workbook and Inserts a new worksheet
using DocumentFormat.OpenXml.Packaging;
using DocumentFormat.OpenXml.Spreadsheet;
using System.Linq;
static void InsertWorksheet(string docName)
{
using (SpreadsheetDocument spreadSheet = SpreadsheetDocument.Open(docName, true))
{
WorkbookPart workbookPart = spreadSheet.WorkbookPart ?? spreadSheet.AddWorkbookPart();
WorksheetPart newWorksheetPart = workbookPart.AddNewPart<WorksheetPart>();
newWorksheetPart.Worksheet = new Worksheet(new SheetData());
Sheets sheets = workbookPart.Workbook.GetFirstChild<Sheets>() ?? workbookPart.Workbook.AppendChild(new Sheets());
string relationshipId = workbookPart.GetIdOfPart(newWorksheetPart);
uint sheetId = 1;
if (sheets.Elements<Sheet>().Count() > 0)
{
sheetId = (sheets.Elements<Sheet>().Select(s => s.SheetId?.Value).Max() + 1) ?? (uint)sheets.Elements<Sheet>().Count() + 1;
}
string sheetName = "Sheet" + sheetId;
Sheet sheet = new Sheet() { Id = relationshipId, SheetId = sheetId, Name = sheetName };
sheets.Append(sheet);
}
}
Console App that checks the content of a file
using DocumentFormat.OpenXml.Packaging;
using DocumentFormat.OpenXml.Spreadsheet;
using System;
class MyConsole
{
static void Main(string[] args)
{
ReadExcelFile(args[0]);
}
static void ReadExcelFile(string filename)
{
try
{
using (SpreadsheetDocument xSD = SpreadsheetDocument.Open(filename, false))
{
WorkbookPart xWBP = xSD.WorkbookPart ?? xSD.AddWorkbookPart();
string text;
foreach (Worksheet xWSP in xWBP.WorksheetParts)
{
Worksheet xwsh = xWSP.Worksheet;
foreach(SheetData xSheetData in xwsh.Elements<SheetData>())
{
foreach(Row xRow in xSheetData.Elements())
{
foreach(Cell xCell in xRow.Elements<Cell>())
{
if (xCell.CellFormula != null)
{
text = xCell.CellFormula.InnerText;
if (text.contains("AVERAGE") == true)
{
Console.WriteLine(@"""" + filename + @"""&&""" + text + @"""");
}
else
{
}
}
}
}
}
}
}
return;
}
catch (Exception ex)
{
Console.WriteLine(@"""" + filename + @"""&&""" + @"""ERROR""");
return;
}
}
}
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext