PicoXLSX 4.0.0

dotnet add package PicoXLSX --version 4.0.0
                    
NuGet\Install-Package PicoXLSX -Version 4.0.0
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="PicoXLSX" Version="4.0.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="PicoXLSX" Version="4.0.0" />
                    
Directory.Packages.props
<PackageReference Include="PicoXLSX" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add PicoXLSX --version 4.0.0
                    
#r "nuget: PicoXLSX, 4.0.0"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package PicoXLSX@4.0.0
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=PicoXLSX&version=4.0.0
                    
Install as a Cake Addin
#tool nuget:?package=PicoXLSX&version=4.0.0
                    
Install as a Cake Tool

PicoXLSX

PicoXLSX

nuget NuGet Downloads GitHub License FOSSA Status

PicoXLSX is a small .NET library written in C#, to create Microsoft Excel files in the XLSX format (Microsoft Excel 2007 or newer) in an easy and native way

  • Minimum of dependencies (*
  • ❌ No need for an installation of Microsoft Office
  • ❌ No need for Office interop libraries
  • ❌ No need for proprietary 3rd party libraries
  • ❌ No need for an installation of the Microsoft Open Office XML SDK (OOXML)

➡️ Please have a look at the codebase library NanoXLSX for the full source code of PicoXLSX and NanoXLSX.

🌐 Project website: https://picoxlsx.rabanti.ch

📄 See the Change Log for recent updates.

📦 Modules

PicoXLSX v4 is split into modular NuGet packages:

Module Status Description
NanoXLSX.Core :green_circle: Mandatory, Bundled Core library with workbooks, worksheets, cells, styles. No external dependencies
NanoXLSX.Writer 🔵 Optional, Bundled Extension methods to write/save XLSX files. Depends on Core
NanoXLSX.Formatting 🔵 Optional, Bundled In-line cell formatting (rich text). External repo. Depends on Core
PicoXLSX ⭐ Meta-Package Bundles all of the above. Recommended for most users
NanoXLSX.Reader ⚪ Optional, Not bundled Extension methods to read/load XLSX files. Depends on Core

Note: All bundled modules are included when you install the PicoXLSX meta-package. Optional, non-bundled modules will extend the functionality of PicoXLSX

For advanced scenarios, you can install only the specific packages you need (e.g. NanoXLSX.Core + NanoXLSX.Reader for read-only applications).

✨ What's new in version 4.x

PicoXLSX v4 is a major release with significant architectural changes:

  • Modular architecture - Split into separate NuGet packages (Core, Reader, Writer, Formatting) with a plugin system
  • New Color system - Unified Color class supporting RGB, ARGB, indexed, theme and system colors
  • Redesigned Font and Fill - Font properties now use proper enums; Fill supports flexible color definitions with tint
  • PascalCase naming - All enums and constants follow C# naming conventions
  • Immutable value types - Address and Range structs are now immutable
  • In-line formatting - Rich text cell formatting via the NanoXLSX.Formatting module
  • Utils reorganization - Utils class split into DataUtils, ParserUtils, Validators

⚠️ Breaking changes from v3.x - There are breaking changes between PicoXLSX v3.4.5 and v4.0.0, mostly related to namespace changes and renamed enum values. See the Migration Guide for detailed upgrade instructions.

🗺️ Roadmap

PicoXLSX v4.x (NanoXLSX v3.x) is planned as the long-term supported version. Possible future enhancements include:

  • 🔒 Modern password handling (e.g. SHA-256 for worksheet protection)
  • 🎨 Auto-formatting capabilities
  • 🔢 Formula assistant for easier formula creation
  • 🖌️ Modern Style builder API
  • 💬 Support for cell comments
  • 🖼️ Embedded images and charts
  • 🚀 Performance optimizations

⚙️ Requirements

The library is currently on compatibility level with .NET version 4.5 and .NET Standard 2.0. Newer versions should of course work as well. Older versions, like .NET 3.5 have only limited support, since newer language features were used.

.NET 4.5 or newer

*)The only requirement to compile the library besides .NET (v4.5 or newer) is the assembly WindowsBase, as well as System.IO.Compression. These assemblies are standard components in all Microsoft Windows systems (except Windows RT systems). If your IDE of choice supports referencing assemblies from the Global Assembly Cache (GAC) of Windows, select WindowsBase and Compression from there. If you want so select the DLLs manually and Microsoft Visual Studio is installed on your system, the DLL of WindowsBase can be found most likely under "c:\Program Files\Reference Assemblies\Microsoft\Framework\v3.0\WindowsBase.dll", as well as System.IO.Compression under "c:\Program Files (x86)\Reference Assemblies\Microsoft\Framework.NETFramework\v4.5\System.IO.Compression.dll". Otherwise you find them in the GAC, under "c:\Windows\Microsoft.NET\assembly\GAC_MSIL\WindowsBase" and "c:\Windows\Microsoft.NET\assembly\GAC_MSIL\System.IO.Compression"

The NuGet package does not require dependencies

.NET Standard

.NET Standard v2.0 resolves the dependency System.IO.Compression automatically, using NuGet and does not rely anymore on WindowsBase in the development environment. In contrast to the .NET >=4.5 version, no manually added dependencies necessary (as assembly references) to compile the library.

🛠️ Development and Testing

The full source code of PicoXLSX is available in the NanoXLSX repository. There are also thousands of unit tests available, ensuring a very high code coverage and security against unwanted side effects on changes.

📥 Installation

By package Manager (PM):

Install-Package PicoXLSX

By .NET CLI:

dotnet add package PicoXLSX

ℹ️ Note: Other methods like adding DLLs or source files directly into your project are technically still possible, but not recommended anymore. Use dependency management, whenever possible

💡 Usage

Quick Start (shortened syntax)

 Workbook workbook = new Workbook("myWorkbook.xlsx", "Sheet1");         // Create new workbook with a worksheet called Sheet1
 workbook.WS.Value("Some Data");                                        // Add cell A1
 workbook.WS.Formula("=A1");                                            // Add formula to cell B1
 workbook.WS.Down();                                                    // Go to row 2
 workbook.WS.Value(DateTime.Now, Style.BasicStyles.Bold);               // Add formatted value to cell A2
 workbook.Save();                                                       // Save the workbook as myWorkbook.xlsx

Quick Start (regular syntax)

 Workbook workbook = new Workbook("myWorkbook.xlsx", "Sheet1");         // Create new workbook with a worksheet called Sheet1
 workbook.CurrentWorksheet.AddNextCell("Some Data");                    // Add cell A1
 workbook.CurrentWorksheet.AddNextCell(42);                             // Add cell B1
 workbook.CurrentWorksheet.GoToNextRow();                               // Go to row 2
 workbook.CurrentWorksheet.AddNextCell(DateTime.Now);                   // Add cell A2
 workbook.Save();                                                       // Save the workbook as myWorkbook.xlsx

🔗 Further References

See the full API-Documentation at: https://rabanti-github.github.io/PicoXLSX/.

The Demo Project contains 25 examples covering various use cases. The demo project is maintained in a separate repository. See the section PicoXLSX for the specific examples related to PicoXLSX.

See also: Getting started in the Wiki

Hint: You will find most certainly any function, and the way how to use it, in the Unit Test Project of nanoXLSX

⚖️ License

PicoXLSX is licensed under the MIT License. See the LICENSE file for more details.

This library claims to be free of any dependencies on proprietary software or libraries. FOSSA Status

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net45 is compatible.  net451 was computed.  net452 was computed.  net46 was computed.  net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on PicoXLSX:

Package Downloads
TagBites.UI.Features.XlsxExports

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
4.0.0 276 3/1/2026
4.0.0-rc.4 110 2/16/2026
4.0.0-rc.3 278 12/3/2025
4.0.0-rc.2 950 12/2/2025 4.0.0-rc.2 is deprecated because it has critical bugs.
4.0.0-rc.1 963 12/1/2025 4.0.0-rc.1 is deprecated because it is no longer maintained.
3.4.5 1,534 10/1/2025
3.4.4 316 9/29/2025
3.4.3 6,665 4/26/2025
3.4.2 15,286 1/24/2025
3.4.1 243 1/19/2025
3.4.0 234 1/12/2025
3.3.2 2,883 11/24/2024
3.3.1 1,713 10/25/2024
3.3.0 4,739 7/23/2024
3.2.1 9,753 2/25/2024
3.2.0 6,213 9/7/2023
3.1.1 15,249 8/9/2023
3.1.0 33,074 11/11/2022
3.0.2 16,599 10/4/2022
3.0.1 544 10/1/2022
Loading failed