How to get Data from Excel to DataTable using ClosedXML in C# and avoid duplicate rows

Ahamed Fazil Buhari
SharePoint Developer
Published On :   21 Jan 2018
Visit Count
Today :  12    Total :   877
Plan, Migrate, Secure, Report
SharePoint & Office 365 Tool. Simple & Easy to Use. 15-Day Trial!

SharePoint Office 365 Tool
Simple & Powerful Tool for Migration, Security & Reporting. Free Trial

Hello everyone,

We had a requirement to read data from Excel and get it in your code. We utilized ClosedXML to achieve this functionality. ClosedXML is one of the useful dll which is used for accessing Excel, XML files and manipulate those files, to know more about ClosedXML – please refer this github. In this article we will see how to easily fetch data from Excel by column names.

Add ClosedXML reference to your project, by going to Manage NuGet Package, as shown below.


As you can see in the below screenshot, we have TestData Excel file in Data folder.


Initially we are getting data from Excel and querying the data based on column name and pass it to a List<string[]> then we are converting it to DataTable using a function ConvertListToDataTable based on your requirement.

 private void GetDataFromExcel()
             var xmlFile = Path.Combine(Environment.CurrentDirectory, "Data\\TestData.xlsx");
             using (var workBook = new XLWorkbook(xmlFile))
                 var workSheet = workBook.Worksheet(1);
                 var firstRowUsed = workSheet.FirstRowUsed();
                 var firstPossibleAddress = workSheet.Row(firstRowUsed.RowNumber()).FirstCell().Address;
                 var lastPossibleAddress = workSheet.LastCellUsed().Address;
                 // Get a range with the remainder of the worksheet data (the range used)
                 var range = workSheet.Range(firstPossibleAddress, lastPossibleAddress).AsRange(); //.RangeUsed();
                 // Treat the range as a table (to be able to use the column names)
                 var table = range.AsTable();
                 //Specify what are all the Columns you need to get from Excel
                 var dataList = new List<string[]>
                         .Select(tableRow =>
                             tableRow.Field("Solution Number")
                         .Select(tableRow => tableRow.Field("Name").GetString())
                     .Select(tableRow => tableRow.Field("Date").GetString())
                 //Convert List to DataTable
                 var dataTable = ConvertListToDataTable(dataList);
                 //To get unique column values, to avoid duplication
                 var uniqueCols = dataTable.DefaultView.ToTable(true, "Solution Number");
                 //Remove Empty Rows or any specify rows as per your requirement
                 for (var i = uniqueCols.Rows.Count - 1; i >= 0; i--)
                     var dr = uniqueCols.Rows[i];
                     if (dr != null && ((string)dr["Solution Number"] == "None" || (string)dr["Title"] == ""))
                 Console.WriteLine("Total number of unique solution number in Excel : " + uniqueCols.Rows.Count);
         private static DataTable ConvertListToDataTable(IReadOnlyList<string[]> list)
             var table = new DataTable("CustomTable");
             var rows = list.Select(array => array.Length).Concat(new[] { 0 }).Max();
             table.Columns.Add("Solution Number");
             for (var j = 0; j < rows; j++)
                 var row = table.NewRow();
                 row["Solution Number"] = list[0][j];
                 row["Name"] = list[1][j];
                 row["Date"] = list[2][j];
             return table;

In the below screenshot you can find all the data in the DataTable.


UniqueCols holds the unique rows in ‘Solution Number’ column,


The reason for getting unique value is that, you can query main DataTable by using this unique value so that you can get all the rows with this particular value.

I hope this article is helpful for you. Thank you for reading

Happy Coding


SharePoint Usage Reports
Usage reports, collaboration and audit for SharePoint.

SharePoint Analytics