Features / Fixed issues - EPPlus 5
Version 5.6.2
Fixed issues
- InvalidOperationException is thrown if Data Validation formula length exceeds 255 characters due to added _xlfn/_xlws prefixes.
- Pivot tables with row/column fields of a enum type corrupted the pivot cache.
- Reading conditional formatting from a workbook causes font and number formats to clear
- Custom data validation could not handle formula reference to other worksheet.
- Normal buildin style causes corruption when a style named Normal exists.
- Optimize handling of image sizing and positioning on save and resizing.
- Exception on copying worksheet with a chart that has no valid X Series.
- Match function could not handle named ranges in the range argument.
- Preserve table names when copying worksheet to a new workbook.
- Number formats with localization did not set the culture code correctly.
Version 5.6.1
Fixed issues & minor features
- Styles xml could get corrupt in some cases as the numFmt dxf element was created in the wrong order according to the schema.
- Merged cells could get index out of range if deleting a merged area.
- LoadFromCollection will now set the cell's Hyperlink property for class members of type Uri or ExcelHyperlink.
- EPPlus will now preserve the 'aca' and 'ca' attributes for array formulas.
- ExcelRange.Formula and ExcelRange.FormulaR1C1 didn't return a value for array formulas except for the first cell in the range.
- Defined names containing #REF! throw an exception when copying a worksheet.
- Worksheet.FirstSheet property was set to the first sheet visible, if worksheet with position 0 was hidden.
Version 5.6.0
Features
- Custom table styles.
- Create and modify names table styles that can be applied to tables and pivot tables.
- Create and modify named slicer styles
- Pivot table styling using pivot areas.
- Enhanced table styling
- Added three new style properties to the ExcelTable and ExcelTableColumn
- HeaderRowStyle
- DataStyle
- TotalsRowStyle
Fixed issues
- Using references to tables in formulas did not work correctly in some cases.
- Functions SUMIFS and AVERAGEIFS ignored hidden cells.
- SUMIFS could not handle horizontal ranges.
- SUMIFS-ExpressionEvaluator could not handle space between operator and criteria. Usage of the Dimension.End.Rows property led to premature stoppage in some cases
- INDEX function should round decimal numbers to integers using floor.
- Calculating shared formulas referencing full columns or full rows gives #ref! on all cells but the first
- Loading worksheets from QXlsx failed.
- Deleting rows with comments throwed an exception in some cases.
- Deleting worksheets with comments throwed an exception in some cases.
- Removed validation for negative less that -60 in Drawing.SetPosition for RowOffset and ColumnOffset
Version 5.5.5
Fixed issues
- Dependency chain sometimes drops refererences when cross-worksheet addresses are used with defined names in the formula parser.
- ExcelWorksheetView ShowHeaders had an incorrect default value causing it not to work.
- Fixed issue when EPPlus crashes on load if a pivot table uses an external source.
- EPPlus will now preserve the 'cm' and 'vm' attributes of the sheet xml - 'c' element
Version 5.5.4
Fixed issues
- Formula calculation returns 0 in some cases when Excel returns null/empty in for example the MIN and MAX functions
- Fixed a bug in SUMIFS function that occured with more than 3 criterias
- The INDEX function could not handle that the range covered the cell containing the formula.
- AutoFilter.ShowButton property did not work.
- Number format "(#,##0)" got incorrectly formatted with a "-" prefix in the ExcelRange.Text property.
- Load using some CultureInfo did not work properly due to different StringComparation behavior.
Version 5.5.3
Fixed issues
- Min and Max could not handle empty ranges. They now returns 0 like Excel does if the range is empty.
- Added fallback for encoding of unknown unicode characters when saving shared strings. Thanks to SamSaint.
- ExcelTableColumnCollection.Insert used an invalid key when creating the name dictionary. Thanks Meigyoku-Thmn
- Fixed ' object reference not set to an instance of an object ' if a middle column cell is null in the ToDataTable method. Thanks to Mengfw
- Added support for handling multiple colons in addresses, e.g. a1:a5:b3
- Fixed handling of the tilde(~) char in WildcardValueMatcher when not being an escape character. Used by If functions.
- Setting styles over empty columns caused cell to be removed in some cases.
- Having pivot table shared items with both null and empty string causes an exception on load.
- Defined names referencing non-existing worksheets caused crash on load.
- Exposed static method RecyclableMemory.SetRecyclableMemoryStreamManager. Thanks to LIFEfreedom.
Version 5.5.2
Fixed issues
- Fixed a bug in ExpressionEvaluator that caused search criteria's starting with a wildcard character to cause an Exception.
- Setting cell value via an array overwriting rich text causes invalid cell content.
- Removed invalid handling of defined names on load if the name contained a link to an external workbook.
- Dependency chain referenced the wrong worksheet in some cases when a formula had off-sheet references when checking for circular references.
- Table headers with rich text caused corrupt workbook.
- Fixed error handling and handling of single cell addresses in COUNTIFS function
- Downgraded .NET 5 referenced packages for .NET standard 2.0 and 2.1 build.
Version 5.5.1
Features
- 10 new functions:
- COMPLEX
- DEVSQ
- AVEDEV
- GAMMALN
- GAMMALN.PRECISE
- GAMMA
- DB
- SHEET
- INTRATE
- MDURATION
Fixed issues
- LoadFromCollection thrown an exception if collection was empty and PrintHeaders was false
- Adding controls after an table was added caused an corrupt workbook.
- PrecisionAndRoundingStrategy.Excel doesn't work in range -1 to 1
- EPPlus no longer validate defined names on load.
- Setting the IsRichText property to true don't convert the value to Rich text properly.
- Xml formatting issue on Saving DrawingXml. Thanks to ZaL133 for pull request.
Version 5.5.0
Features
- Form Controls
- Buttons
- Drop-Downs
- List Boxes
- Check Boxes
- Radio Buttons
- Spin Buttons
- Scroll Bars
- Labels
- Group Boxes
- Group/Ungroup drawing object via the ExcelDrawing.Group and ExcelDrawing.Ungroup methods
- New attribute support for LoadFromCollection. See https://github.com/EPPlusSoftware/EPPlus/wiki/LoadFromCollection-using-Attributes
- 20 new functions
- AGGREGATE
- PERCENTILE.EXC
- DATEDIF
- QUARTILE.EXC
- STDEVA
- STDEVPA
- VARA
- VARPA
- COVAR
- COVARIANCE.P
- COVARIANCE.S
- RANK
- DOLLAR
- DOLLARDE
- DOLLARFR
- PERMUT
- PERMUTATIONA
- XOR
- MULTINOMIAL
- YIELDMAT
Fixed issues & minor fixes
- Round methods can now use only 15 sigificant figures with calculation option - PrecisionAndRoundingStrategy
- R1C1 causes corrupt worksheet if used as shared formula with off-sheet reference.
- Using double qoutes in R1C1 didn't encode correctly.
- Altering fields on a table connected to a pivot table causes the pivot table to become corrupt.
- Pivot tables with a boolean column and a filter got corrupt on save.
- Deleting a worksheet and adding it again with the same name causes a crash on save if the worksheet is referenced by a pivot table. This happends due to the SourceRange property still referencing the deleted worksheet.
- Changed ExcelAddressBase.FullName to public
- Reference table name only in indirect formula did not work.
- Replaced MemoryStrem internally with Microsoft.IO.RecyclableMemoryStream. Thanks to LIFEfreedom.
- Referencing a single cell with rich text from a formula returned an invalid value.
- Reverted .NET 5.0 references for .NET standard 2.0 and 2.1, to be compatible with Azure Functions.
Version 5.4.2
Fixed issues
- .NET 5.0 to Nuget package.
- Deselecting pivot table items did not work for null values in some cases
- Deleting a worksheet containing a pivot table was not properly cleaned.
- Save crashed if a pivot tables shared items had the same string value with different case.
- Reading Hyperlinks in the format #'sheet'!A1 will now work.
- Fixed an issue with some table properties overwiting other table properties
- Fixed an issue with Range.SaveToText hanging with the FileInfo overload
- ExcelShape.SetFromFont did not set fonts correctly
- Inserting more than 32K rows at once did not work.
- Worksheets with gaps of more than 32K rows causes invalid values to be returned in some cases.
Version 5.4.1
Minor new features
- WriteProtection added to Workbook.Protection. Allows to set a workbook to read-only with a password.
- ToDataTable method added to ExcelRange
Fixed issues
- Worksheet names starting with R1C1 format creates invalid addresses
- Row array in pages in the cell store caused an index out of bounds exception in rare cases.
- Setting a shared formula with an external reference causes the workbook to become corrupt in some Excel versions
- A Pivot table get corrupt if a TimeSpan is used in a column that needs shared items in the cache.
- Cell.Text returns an incorrect text when formatted #,##0;#,##0;- and value is rounded to zero.
- Delete Table With ExcelTableCollection.Delete() did not remove the xml in the package causing the table not to be deleted.
- Pivot tables with 'Save source data with file' caused an exception.
- Signing VbaProject under .NET core did not work correcly.
Version 5.4.0
Features
- Pivot tables filters
- Item filters - Filters on individual items in row/column or page fields.
- Caption filters (label filters) - Filters for text on row and column fields.
- Date, numeric and string filters - Filters using various operators such as Equals, NotBetween, GreaterThan, etc.
- Top 10 filters - Filters using top or bottom criterias for percent, count or value.
- Dynamic filters - Filters using various date- and average criterias.
- Add calculated fields to pivot tables.
- Support for pivot table shared caches via the new overload for PivotTables.Add.
- Support for pivot table slicers
- Support for table slicers
Minor new features
- Number format property has been added to pivot fields and pivot cache fields.
- Added PivotTableStyle property and enum for easier setting all pivot table styles
Fixed issues
- Chart series indexes got corrupt when removing and adding series in some cases.
- Inheriting cells styling from column to cell did not work correctly in some cases.
Version 5.3.2
Fixed issues
- Workbook got corrupt on copy if a worksheet VBA Code module was null.
- Setting chart series color settings to WithinLinear caused an exception in some cases.
- LoadFromCollection did not load all members as in previous version when suppling binding flags and MemberInfo's.
- If first worksheet(s) are hidden in the worksheet collection, print preview crashed in Excel.
- Worksheet Move methods failed with a crash in some cases.
Version 5.3.1
Features
- Added support for copying threaded comments
- Add FormulaParserManager.Parse method.
Fixed issues
- Formulas and formula values did not encode characters below 0x1F correctly
- ExcelPackage.LoadAsync did not work with non seekable streams
- A chart that reference within its own worksheet will now change the worksheet in the series addresses for any copy made with the Worksheets.Add method
- ExcelRange.ToText method did not work correctly with rich text cells.
Version 5.3.0
Features
- Support for threaded comments with mentions. See https://github.com/EPPlusSoftware/EPPlus/wiki/Threaded-comments
- Support for two new functions:
- MINIFS
- MAXIFS
Fixed issues
- Removed the extra comman added to the end of the header row in the ExcelRange.ToText method.
- The abstract class ExcelChart missed the properties DisplayBlankAs, RoundedCorners, ShowDataLabelsOverMaximum, ShowHiddenData after the version 5.2 update. The properties have been moved back again.
- ExcelColorXml.Indexed returned 0 if was not set, causing the LookupColor method to return an incorrect color.
Version 5.2.1
Features
- New method ExcelRange.LoadFromDictionary.
- Support for Dynamics in ExcelRange.LoadFromCollection (ExpandoObject).
- New Lambda config parameter to ExcelRange.LoadFromCollection with new options for header parsing (for example: UnderscoreToSpace, CamelCaseToSpace)
- Zip64 support in packaging to enable larger packages.
Fixed issues
- Wildcards in MATCH function not working
- Performance issue in ExpressionEvaluator.GetNonAlphanumericStar
- Using the sheet name to reference the entire worksheet did not work in formulas.
- GetAsByteArray corrupted the package if ExcelPackage.Save was called before.
- Parsing issue in the Value function
Version 5.2.0
Features
Support for extended chart types and Stock charts:
- Four types of stock charts: High-Low-Close, Open-High-Low-Close, Volume-High-Low-Close and Volume-Open-High-Low-Close
- Sunburst Chart
- Treemap Chart
- Histogram Chart
- Pareto Chart
- Funnel Chart
- Waterfall Chart
- Box & Whisker Chart
- Region Map Chart
Support for 49 new functions:
- BESSELI
- BESSELJ
- BESSELK
- BESSELY
- COUPDAYBS
- COUPDAYS
- COUPDAYSNC
- COUPNCD
- COUPNUM
- COUPPCD
- CUMIPMT
- CUMPRINC
- DDB
- DISC
- DURATION
- EFFECT
- ERF
- ERF.PRECISE
- ERFC
- ERFC.PRECISE
- FV
- FVSCHEDULE
- IPMT
- IRR
- ISPMT
- MIRR
- MODE
- MODE.SNGL
- NOMINAL
- NPER
- NPV
- PDURATION
- PERCENTILE
- PERCENTILE.INC
- PERCENTRANK
- PERCENTRANK.INC
- PPMT
- PRICE
- PV
- RATE
- RRI
- SLN
- SYD
- TEXTJOIN
- VAR.P
- VAR.S
- XIRR
- XNPV
- YIELD
Four new properties to Style.Font
- Charset
- Condense
- Extend
- Shadow
Added * New
As
property to the Drawing, ConditionalFormatting and DataValidation objects for easier type cast. For examplevar sunburstChart = worksheet.Drawings[0].As.Chart.SunburstChart;
orvar listDv = sheet.DataValidations.First().As.ListValidation;
OFFSET function calculation can now be a part of a range in formula calculation. For example
SUM(A1:OFFSET(A3, -2, 0))
Added ShowColumnHeaders, ShowColumnStripes, ShowRowHeaders, ShowRowStripes and ShowLastColumn properties to ExcelPivotTable
Fixed issues
- Ignore a leading "_xlfn." in function names when calculating formulas.
- Only the fist paragraph was loaded when the RichText property was loaded from the XML.
- VerticalAlign property did not delete the XmlNode properly when set to None.
- A named style with a missing fontid crashed on load.
- Deleting a worksheet in a macro enabled workbook causes a NullReferenceException.
Version 5.1.2
Features
- Added ClearFormulas and ClearFormulaValues to Range, Worksheet and Workbook. ClearFormulas removes all formulas, ClearFormulaValues removes all previously calculated/cached values.
- Added support for 19 new engineering functions:
- CONVERT
- DELTA
- BIN2DEC
- BIN2HEX
- BIN2OCT
- DEC2BIN
- DEC2HEX
- DEC2OCT
- HEX2BIN
- HEX2DEC
- HEX2OCT
- OCT2BIN
- OCT2DEC
- OCT2HEX
- BITLSHIFT
- BITAND
- BITOR
- BITRSHIFT
- BITXOR
Fixed issues
- Delete method adjusted row offset on drawings incorrectly.
- When copying a worksheet with images to an other package did not work correctly in some cases.
- Datavalidation addresses did not update correctly when deleting columns.
- Opening a packages saved with System.IO.Compression caused a corrupted package on save.
- Added a check to the ExcelPackage Construcors if the FileInfo exists and is zero-byte. Supplying a zero-byte file will now create a new package. Supplying a zero-byte template will throw an exception.
- Fixed scaling for pictures. Changed data type for internal pixel variables from int to double.
- Delete/Insert din't handle comma separated addresses in data validation / conditional formatting
- ColumnMin and ColumnMax were not correctly updated when one or more columns were deleted.
Version 5.1.1
Features
- Added method RemoveVBAProject to ExcelWorkbook.
Fixed issues
- CalculatedColumnFormula property was set to the range on save, overwriting any cell value that was changed in the range of the formula.
- VbaProject. Remove didn't fully remove the VBA project.
- LoadFromCollection didn't work will List<object>.
- Group shapes containg shapes with the same name throw exception.
- Worksheets with a large amount of columns had bad performance on save.
Version 5.1.0
Features
- Insert and Delete method added to ExcelRange. Cells will be shifted depending on the argument supplied.
- AddRow, InsertRow and DeleteRow added to ExcelTable.
- Add, Insert and Delete added To ExcelTableColumnCollection.
- Added support for new functions:
- FACTDOUBLE
- COMBIN
- COMBINA
- SEC
- SECH
- CSC
- CSCH
- COT
- COTH
- RADIANS
- ACOT
- ACOTH
- ROMAN
- GCD
- LCM
- FLOOR.PRECISE
- CEILING.PRECISE
- MROUND
- ISO.CEILING
- FLOOR.MATH
- CEILING.MATH
- SUMXMY2
- SUMX2MY2
- SUMX2PY2
- SERIESSUM
Fixed issues
- Images added with AddImage(Image) did not use the oneCellAnchore element.
- ExcelPackage.CopyStreamAsync did not fully use async (Flush-->FlushAsync), causing an exception.
- VBA module names restricts some allowed characters.
- Shared Formulas are not handled correctly when an address argument reference another worksheet.
- Adding a Sparklinegroup does not add it to the SparklineGroups collection.
- Files saved in LibreOffice did not handle boolean properties correctly for rows and columns, (for example the hidden property).
- Data validation - List validation did not set the ShowErrorMessage when an address referenced another worksheet.
- Addresses with style: 'sheet'!A1:'sheet'!A2 was not handled correctly.
Version 5.0.4
Fixed issues
- Datavalidation on lists failed if the formula was an defined name.
- Merged cells got cleared if a value was set over multiple cells
- RichText causes xml "corruption" if a blank string or null was added to the collection.
Version 5.0.3
Minor new features
- Chart series will from version 5 handles both addresses and arrays. Arrays are handled in the StringLiteralsX, NumberLiteralsX and NumberLiteralsY arrays when a series is set to an Array ( for example {1,2,3} ).
- Add support for BringToFront and SendToBack methods on the Drawings Collection to handle drawing overlap.
- Add TopLeftCell to ExcelWorksheetView
- Enabled Style.TextRotation=255 for Vertical Text in cells. Added new method ExcelStyle.SetTextVertical.
- Add Pivot property to conditional formatting, to indicate a pivot source.
- RichText on drawings can now handle paragraphs to get line breaks. Add method has new parameter NewParagraph.
- Table source overload to PivotTable.Add method
- 13 new functions supported in the Formula calculation engine: IFS, SWITCH, WORKDAY.INTL, TYPE, ODD, EVEN, DAYS, NUMBERVALUE, UNICHAR, UNICODE, CLEAN, TRIM and CONCAT
General fixes
- Cellstore has been rewritten. This should fix some issues with inserting and deleting rows and columns. Also fixes a sorting issue.
- Fixed SchemaNodeOrder in many drawing classes.
- Handling of circular references has been redesigned.
Fixed issues
- Worksheet.Hidden does not always hide the worksheet.
- Drawings will now move and size when inserting/deleting rows/columns depending on the ExcelDrawing.EditAs property.
- Adding a Table caused an exception if a chart sheet existed in the workbook.
- Adding a PivotTable caused an exception if a chart sheet existed in the workbook.
- Custom document properties are case insensitive.
- Sheet with rich text inline string can not handle whitespaces only.
- StackOverflowException when calling Clear on a comma separated Range.
- ExcelWorksheet.Copy corrupts package if a relationship to drawing.xml with no drawings exists.
- Copying formulas in ranges can lead to invalid #REF! for fixed addresses.
- Table column names are validated for duplicates on a non-encoded value
- Packages with a prefix for the main xml namespace for a worksheet gets corrupted.
- ExcelRangeBase.AutofitColumns() unhides hidden columns
- The Normal style does not work correctly if not named Normal. The Normal style is now found using the first occurrance of the BuildInId = 0 criteria.
- URI for the sharedstrings and the styles part were not fetched by RelationshipType when a package was loaded.
- Setting a cell value to a char datatype will result i "0" when saved
- Structs in a cell value can result in a null value when converted to string on save
- Conditional formatting styles crashed when copying a worksheet from another package.
- EPPlus crashes on load if a workbook or worksheet has more than one defined name with the same name.
- Row styles were not copied correctly copied when inserting rows
- Overwriting a shared formulas first cell causes a crash.
- Workbooks with Empty series for Scatter- and Doughnut- charts crashes on load
- FileStream for compound documents are not closed.
- If CustomSheetView element contained row/column breaks, the package could not be loaded.
- Pivot tables crashed if SubTotalFunction were set to eSubTotalFunctions.None and there were no values in the source data.
- Data validations of type list don't support formula references to other worksheets.
- Formula calc: Does not remove double-negation from formulatokens.
- Formula calc: Value matcher now supports comparisons between DateTime and double. CompileResultFactory includes float type in DataType.Decimal.
- Formula calc: MultipleRangeCriterasFunction.GetMatchIndexes() looped through max number of rows when a range argument was an entire column now stops as Dimension.End.Row. Fixed a bug in CountIfs function which wasn't working properly with multiple criteria's
- Formula calc: Support Instance_num parameter of SUBSTITUTE function.