Release Date: 12.01.2025
- Added InsertRow and InsertColumn functions. Functionality provided by Alexander Schlecht
- Added FirstCewllByValue, FirstOrDefaultCell, CellsByValue functions. Functionality provided by Alexander Schlecht
- Added ReplaceCellValue function. Functionality provided by Alexander Schlecht
- Code maintenance
Release Date: 24.11.2024
- Fixed a bug of the column address (letter) resolution. Column letters above 'Z' were resolved incorrectly
- Changed async handing of the workbook reader, to avoid deadlocks. Change provided by Jarren Long
- Simplified project structure (unified .Net 4.x and Standard). Change provided by Jarren Long
- Added tests for column address resolution
Release Date: 26.10.2024
- Fixed a bug regarding the determination of the first data cell in an empty worksheet. Bug fix provided by Martin Stránský
Release Date: 22.07.2024
- Adapted handling of the font scheme in styles. The scheme is now determined automatically
- Added column option to define a default column style
- Added tests
Release Date: 21.04.2024
- Added handling to load workbooks from files asynchronously. Concept provided by John Leyva
- Fixed a bug when loading a workbook asynchronously from a stream. Bug fix provided by John Leyva
- Fixed a bug when the column auto-filter is a single cell address. Bug fix provided by pokorny
- Fixed a bug regarding style enumeration when reading a workbook. Bug fix provided by Martin Stránský
- Added new and adapted existing test cases
Release Date: 24.02.2024
- Fixed a bug in the GetFirstDataCellAddress function
- Fixed test cases
Release Date: 24.02.2024
- Fixed a bug when reading min and max values in the GetLastDataColumnNumber function. Bug fix provided by pokorny
- Code maintenance
Release Date: 22.01.2024
- Fixed a bug when reading fill styles. Bug fix provided by Marq Watkin
- Fixed a bug regarding casting floats to integers, in the worksheet reader. Bug fix provided by wappenull
- Removed broken debug code in tests
- Code maintenance
Release Date: 07.09.2023
- Added worksheet option for zoom factors
- Added worksheet option for view types (e.g. page break preview)
- Added worksheet option to show or hide grid lines
- Added worksheet option to show or hide columns and row headers
- Added worksheet option to show or hide rulers in page layout view type
Release Date: 23.04.2023
- Added new import option to cast all single values into decimals. Feature implementation provided by Tim M. Madsen
- Adapted hex color validation (clarified number of necessary characters)
- Internal changes of build processes (Documentation generation is performed now by a GitHub Action)
Release Date: 04.03.2023
- Fixed a bug when a workbook contains charts instead of worksheets. Bug fix provided by Iivari Mokelainen
- Minor code maintenance
Release Date: 08.11.2022
- Added a several methods in the Worksheet class to add multiple ranges of selected cells
- Fixed a bug in the reader function to read worksheets with multiple ranges of selected cells
- Fixed a bug in several readers to cope (internally) with bools, represented by numbers and textual expressions
- Removed internal escaping of custom number format codes for now
- Updated example in demo
Note: It seems that newer versions of Excel may store boolean attributes internally now as texts (true/false) and not anymore as numbers (1/0). This release adds compatibility to read this newer format but will currently store files still in the old format
Note 2: The incomplete internal escaping of custom number format codes was removed due to the potential high complexity. Escaping must be performed currently by hand, according to OOXML specs: Part 1 - Fundamentals And Markup Language Reference, Chapter 18.8.31
Release Date: 04.10.2022
- Fixed a bug in the reader function of dates and times on hosts with locales different than en-US (and others)
- Added == and != operator overload on Address and Range struct
- Code maintenance
Release Date: 01.10.2022
- Fixed a bug in the functions to write and read font values (styles)
- Adapted tests according to specs
- Updated documentation
- Added some internal notes to prepare the development of the next mayor version
Release Date: 29.09.2022
- Fixed a bug in the functions to write and read custom number formats
- Fixed behavior of empty cells and added re-evaluation if values are set by the Value property
- Adapted and added further tests
- Removed several obsolete files and fixed project links
Note:
- When defining a custom number format, now the CustomFormatCode property must always be defined as well, since an empty value leads to an invalid Workbook
- When a cell is now created (by constructor) with the type EMPTY, any passed value will be discarded in this cell
Release Date: 10.09.2022
- Fixed a bug when loading workbooks on hosts with locales different than en-US (and others)
Release Date: 03.09.2022 - Major Release
- Added a list of MRU colors that can be defined in the Workbook class (methods AddMruColor, ClearMruColors)
- Added an exposed property for the workbook protection password hash (will be filled when loading a workbook)
- Added the method SetSelectedWorksheet by name in the Workbook class
- Added two methods GetWorksheet by name or index in the Workbook class
- Added the methods CopyWorksheetIntoThis and CopyWorksheetTo with several overloads in the Workbook class
- Added the method RemoveWorksheet by index with the option of resetting the current worksheet, in the Workbook class
- Added the method SetCurrentWorksheet by index in the Workbook class
- Added the method SetSelectedWorksheet by name in the Workbook class
- Added a Shortener-Class constructor with a workbook reference
- The shortener methods Down and Right have now an option to keep row and column positions
- Added two shortener methods Up and Left
- Made several non-functional style assigning methods deprecated in the Workbook class (will be removed in future versions)
- Added an exposed property for the worksheet protection password hash (will be filled when loading a workbook)
- Added the methods GetFirstDataColumnNumber, GetFirstDataColumnNumber, GetFirstDataRowNumber, GetFirstRowNumber, GetLastDataColumnNumber, GetFirstCellAddress, GetFirstDataCellAddress, GetLastDataColumnNumber, GetLastDataRowNumber, GetLastRowNumber, GetLastCellAddress, GetLastCellAddress and GetLastDataCellAddress
- Added the methods GetRow and GetColumns by address string or index
- Added the method Copy to copy a worksheet (deep copy)
- Added a constructor with only the worksheet name as parameter
- Added and option in GoToNextColumn and GoToNextRow to either keep the current row or column
- Added the methods RemoveRowHeight and RemoveAllowedActionOnSheetProtection
- Renamed columnAddress and rowAddress to columnNumber and rowNumber in the AddNextCell, AddCellFormula and RemoveCell methods
- Added several validations for worksheet data
- In a Cell object, the address can now have reference modifiers ($)
- The worksheet reference in the Cell constructor was removed. Assigning to a worksheet is now managed automatically by the worksheet when adding a cell
- Added a property CellAddressType in the Cell class
- Cells can now have null as value, interpreted as empty
- Added a new overloaded method ResolveCellCoordinate to resolve the address type as well
- Added the methods ValidateColumnNumber and ValidateRowNumber in the Cell class
- In Address, the constructor with string and address type now only needs a string, since reference modifiers ($) are resolved automatically
- Address objects are now comparable
- Implemented better address validation
- Range start and end addresses are swapped automatically, if reversed
- Font class has now an enum of possible underline values (e.g. instead of a bool)
- CellXf class supports now indentation
- A new, internal style repository was introduced to streamline the style management
- Color (RGB) values are now validated (Fill class has a method ValidateColor)
- Style components have now more appropriate default values
- MRU colors are now not collected from defined style colors anymore, but from the MRU list in the workbook object
- The ToString function of styles and all sub parts will now give a complete outline of all elements
- Fixed several issues with style comparison
- Several style default values were introduced as constants
- Added uint as possible formula value. Valid types are int, uint, long, ulong, float, double, byte, sbyte, decimal, short and ushort
- Added several validity checks
- Added default values for dates, times and culture info in the import options
- Added global casting import options: AllNumbersToDouble, AllNumbersToDecimal, AllNumbersToInt, EverythingToString
- Added column casting import options: Double, Decimal
- Added global import options: EnforcePhoneticCharacterImport, EnforceEmptyValuesAsString, DateTimeFormat, TemporalCultureInfo
- Added a meta data reader for workbook meta data
- All style elements that can be written can also be read
- All workbook elements that can be written can also be read (exception: passwords cannot be recovered)
- All worksheet elements that can be written can also be read (exception: passwords cannot be recovered)
- Better handling of dates and times, especially with invalid (too low and too high numbers) values
- Added a unit test project with several thousand, partially parametrized test cases
- Added several constants for boundary dates in the Utils class
- Added several methods for pane splitting in the Utils class
- Exposed the (legacy) password generation method in the Utils class
- Updated documentation among the whole project
- Exceptions have no sub titles anymore
- Overhauled the whole writer
- Removed lot of dead code for better maintenance
Release Date: 06.08.2022
- Fixed a bug when setting a workbook protection password
Release Date: 02.04.2022
- Added an import option to display phonetic characters (like Ruby Characters / Furigana / Zhuyin / Pinyin are now discarded) in strings
Note: Phonetic characters are discarded by default. If the import option "EnforcePhoneticCharacterImport" is set to true, the phonetic transcription will be displayed in brackets, right after the characters to be transcribed
Release Date: 27.03.2022
- Fixed a follow-up issue on finding first/last cell addresses on explicitly defined, empty cells
- Code maintenance
Release Date: 20.03.2022
- Fixed a regression bug, caused by changes of v1.8.3
Release Date: 10.03.2022
- Added functions to determine the first cell address, column number or row number of a worksheet
- Adapted internal style handling
- Adapted the internal building of XML documents
- Fixed a bug in the handling of border colors
Release Date: 20.12.2021
- Added hidden property for worksheets when loading a workbook
Note: The reader functionality on worksheets is not feature complete yet. Additional information like panes, splitting, column and row sizes are currently in development
Release Date: 12.09.2021
- Fixed a bug when hiding worksheets
Note: It is not possible anymore to remove all worksheets from a workbook, or to set a hidden one as active. This would lead to an invalid Excel file
Release Date: 10.07.2021
- Added functions to split (and freeze) a worksheet horizontally and vertically into panes
- Added a property to set the visibility of a workbook
- Added a property to set the visibility of worksheets
- Added two examples in the demo for the introduced split, freeze and visibility functionalities
- Added the possibility to define column widths and row height even if there are no cells defined
- Fixed the internal representation of column widths and row heights
- Minor code maintenance
Note: The column widths and row heights may change slightly with this release, since the actual (internal) width and height is now applied when setting a non-standard column width or row height
Release Date: 05.06.2021
- Added functions to determine the last row, column or cell with data
- Fixed documentation formatting issues
- Updated readme and documentation
Release Date: 18.04.2021
- Introduced library version for .NET Standard 2.0 (and assigned demos)
- Updated project structure (two projects for .NET >=4.5 and two for .NET Standard 2.0)
- Added function SetStyle in the Worksheet class
- Added demo for the new SetStyle function
- Changed behavior of empty cells. They are now not string but implicit numeric cells
- Added new function ResolveEnclosedAddresses in Range class
- Added new function GetAddressScope in Cell class
- Fixed the validation of cell addresses (single cell)
- Defined several immutable lists as return values to IReadOnlyList
- Minor code maintenance
Thanks to the following people (in the order of contribution date):
- Shobb for the introduction of IReadOnlyList
- John Lenz for the port to .NET Standard
- Ned Marinov for the proposal of the new SetStyle function
Release Date: 10.12.2020
- Added indentation property of horizontal text alignment (CellXF) as style
- Added example in demo for text indentation
- Code Cleanup
Release Date: 13.09.2020
- Fixed a bug regarding numeric cells in the worksheet reader. Bug fix provided by John Lenz
- Minor code maintenance
- Updated readme and documentation
Release Date: 30.08.2020
- Added style reader to resolve dates and times properly
- Added new data type TIME, represented by TimeSpan objects in reader and writer
- Changed namespace from 'Styles' to 'NanoXLSX.Styles'
- Added time (TimeSpan) examples to the demos
- Added a check to ensure dates are not set beyond 9999-12-31 (limitation of OAdate)
- Updated documentation
- Fixed some code formatting issues
- To be consistent, the namespace of 'Styles' was changed to 'NanoXLSX.Styles'. Minor changes may be necessary in existing code if styles were used
- Currently, the style reader resolves only number formats to determine dates and times, as well as custom formats. Other components like fonts, borders or fills are neglected at the moment
Release Date: 19.07.2020
- Fixed a bug in the reader regarding dates, times and booleans
- Fixed a bug in the method AddNextCellFormula
Note: Fixes provided by Silvio Burger and Thiago Souza. The fix for the reader bug is currently a work-around
Release Date: 10.01.2020
- Fixed a bug in the reader regarding decimal numbers (for locales where the decimal pointer is not a dot)
- Formal changes
Release Date: 01.12.2019
- Fixed a bug of reorganized worksheets (when deleted in Excel)
- Fixed a bug in the handling of shared strings
- Minor code maintenance
Release Date: 20.05.2019
- Fixed a bug in the handling of streams (streams can be left open now)
- Updated stream demo
- Code Cleanup
- Removed executable folder, since executables are available through releases, compilation or NuGet
Release Date: 08.12.2018
- Improved the performance of adding stylized cells by factor 10 to 100
Release Date: 04.11.2018
- Fixed a bug in the style handling of merged cells. Bug fix provided by David Courtel for PicoXLSX
Release Date: 06.10.2018
- Added missing features of PicoXLSX (synced with PicoXLSX version 2.6.1)
- Added asynchronous methods SaveAsync, SaveAsAsync, SaveAsStreamAsync and LoadAsync
- Added a new example for the introduced async methods
- Renamed namespace Exception to Exceptions
- Renamed namespace Style to Styles
- Fixed a bug regarding formulas in the reader
- Added support for dates in the reader
- Documentation Update
- Removed redundant code
Release Date: 24.08.2018
- Fixed a bug regarding formulas in the reader
- Added support for dates in the reader
- Documentation Update
Release Date: 24.08.2018
- Initial Release (synced to v 1.2.3 of NanoXLSX4j for Java)