-
Notifications
You must be signed in to change notification settings - Fork 277
Reading and Writing Data
You can read and write data from and to your spreadsheet in a few different ways. The most obvious is to use the Cells
property of the ExcelWorksheet
class, shown on the Getting Started page. There are also a few other ways to import/export/read data from/into spreadsheets with EPPlus.
From the Cells
property (ExcelRange) you can access these methods to load data from various sources:
-
LoadFromText
andLoadFromTextAsync
- Read a text file (csv, tsv, etc) and load the data into a range on a worksheet. -
LoadFromDataReader
andLoadFromDataReaderAsync
- Loads data into a range from anIDataReader
-
LoadFromDataTable
- Loads data into a range from aSystem.Data.DataTable
. Can be used for importing data from a range of sources, like XML (example provided) and databases. -
LoadFromCollection
- Loads data into a range from anIEnumerable<T>
using reflection. -
LoadFromCollection using attributes
- Loads data into a range/table from anIEnumerable<T>
using reflection. Uses attributes that specifies styling, number formats, formulas, etc. -
LoadFromDictionaries
- Loads data into a range from anIEnumerable
ofExpandoObject
/dynamic
objects (via theirIDictionary<string, object>
interface. Useful for importing json data, example provided. -
LoadFromArrays
- Loads data into a range from anIEnumerable
ofobject[]
where each object array becomes a row in the worksheet.
You can optionally specify a parameter to create an ExcelTable
when you use these methods. For more detailed examples, have a look at sample 4 & 5 the sample project Sample-.NET Framework or Sample-.NET Framework.
From the Cells
property (ExcelRange) you can access these methods to write:
-
ToText
andToTextAsync
- Writes a range to a csv string. -
SaveToText
andSaveToTextAsync
- Writes a range to a csv file. -
ToDataTable
- Exports data from a range to aSystem.Data.DataTable
-
ToCollection
- Exports data from a range to anIEnumerable<T>
where T is a class. -
ToJson
- Exports data from a range to Json. -
CreateHtmlExporter
- Exports data from a range to html/css. -
GetValue<T>
- Gets a value, with the option to specify a datatype -
Value
- Gets or sets the value of the range.
You can also use the GetValue
and SetValue
methods directly on the worksheet object.
(This will give a little bit better performance than reading/writing via the range):
-
GetValue<T>
- Gets a value of a single cell, with the option to specify a datatype -
SetValue
- Sets a value of a single cell
Since the Cells property implements the IEnumerable
interface, you can use Linq to query data from a worksheet.
var query1= (from cell in sheet.Cells["d:d"] where cell.Value is double && (double)cell.Value >= 9990 && (double)cell.Value <= 10000 select cell);
Most of these methods are demonstrated in the sample project.
EPPlus Software AB - https://epplussoftware.com
- What is new in EPPlus 5+
- Breaking Changes in EPPlus 5
- Breaking Changes in EPPlus 6
- Breaking Changes in EPPlus 7
- Addressing a worksheet
- Dimension/Used range
- Copying ranges/sheets
- Insert/Delete
- Filling ranges
- Sorting ranges
- Taking and skipping columns/rows
- Data validation
- Comments
- Freeze and Split Panes
- Header and Footer
- Autofit columns
- Grouping and Ungrouping Rows and Columns
- Formatting and styling
- Conditional formatting
- Using Themes
- Working with custom named table- or slicer- styles