QuestPDF 2022.12.12

There is a newer version of this package available.
See the version list below for details.
dotnet add package QuestPDF --version 2022.12.12                
NuGet\Install-Package QuestPDF -Version 2022.12.12                
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="QuestPDF" Version="2022.12.12" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add QuestPDF --version 2022.12.12                
#r "nuget: QuestPDF, 2022.12.12"                
#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.
// Install QuestPDF as a Cake Addin
#addin nuget:?package=QuestPDF&version=2022.12.12

// Install QuestPDF as a Cake Tool
#tool nuget:?package=QuestPDF&version=2022.12.12                

QuestPDF Homepage Getting started tutorial API reference Patterns and Practices GitHub Repo stars Nuget version Nuget download

QuestPDF is a modern open-source .NET library for PDF document generation. Offering comprehensive layout engine powered by concise and discoverable C# Fluent API. Easily generate PDF documents, reports, invoices, exports etc.

Usage animation of the PDF library

👨‍💻 Design PDF documents using C# and employ a code-only approach. Utilize your version control system to its fullest potential.

🧱 Compose PDF document with a range of powerful and predictable structural elements, such as text, image, border, table, and many more.

⚙️ Utilize a comprehensive layout engine, specifically designed for PDF document generation and paging support.

📖 Write code using concise and easy-to-understand C# Fluent API. Utilize IntelliSense to quickly discover available options.

🔗 Don't be limited to any proprietary scripting language or format. Follow your experience and leverage all modern C# features.

⌛ Save time thanks to a hot-reload capability, allowing real-time PDF document preview without code recompilation.

Simplicity is the key

How easy it is to start and prototype with QuestPDF? Really easy thanks to its minimal API! Please analyse the code below that generates basic PDF document:

using QuestPDF.Fluent;
using QuestPDF.Helpers;
using QuestPDF.Infrastructure;

// code in your main method
Document.Create(container =>
{
    container.Page(page =>
    {
        page.Size(PageSizes.A4);
        page.Margin(2, Unit.Centimetre);
        page.Background(Colors.White);
        page.DefaultTextStyle(x => x.FontSize(20));
        
        page.Header()
            .Text("Hello PDF!")
            .SemiBold().FontSize(36).FontColor(Colors.Blue.Medium);
        
        page.Content()
            .PaddingVertical(1, Unit.Centimetre)
            .Column(x =>
            {
                x.Spacing(20);
                
                x.Item().Text(Placeholders.LoremIpsum());
                x.Item().Image(Placeholders.Image(200, 100));
            });
        
        page.Footer()
            .AlignCenter()
            .Text(x =>
            {
                x.Span("Page ");
                x.CurrentPageNumber();
            });
    });
})
.GeneratePdf("hello.pdf");

Minimal PDF example

Let's get started

Begin exploring the QuestPDF library today. You are 250 lines of C# code away from creating a fully functional PDF invoice implementation.

Read the Getting Started tutorial to familiarize yourself with general library architecture, important layout structures as well as to better understand helpful patterns and practices.

Easily start designing your PDF documents, reports, invoices, exports and even more.

Getting started tutorial

Example invoice

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 is compatible.  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. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 is compatible.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework 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 (39)

Showing the top 5 NuGet packages that depend on QuestPDF:

Package Downloads
AgentHub.Service.Financial.Domain.Shared

Package Description

HTMLToQPDF

Relorer.QuestPDF.HTML is an extension for QuestPDF that allows to generate PDF from HTML

DH.QuestPDF

DH框架的Pdf处理库。基于https://github.com/QuestPDF/QuestPDF

SHARIZ.Infrastructure

Package Description

Verify.QuestPDF

Extends Verify (https://github.com/VerifyTests/Verify) to allow verification via QuestPDF.

GitHub repositories (16)

Showing the top 5 popular GitHub repositories that depend on QuestPDF:

Repository Stars
beto-rodriguez/LiveCharts2
Simple, flexible, interactive & powerful charts, maps and gauges for .Net, LiveCharts2 can now practically run everywhere Maui, Uno Platform, Blazor-wasm, WPF, WinForms, Xamarin, Avalonia, WinUI, UWP.
Pixeval/Pixeval
Wow. Yet another Pixiv client!
ariacom/Seal-Report
Database Reporting Tool and Tasks (.Net)
neozhu/CleanArchitectureWithBlazorServer
This is a repository for creating a Blazor Server dashboard application following the principles of Clean Architecture
ZeusAutomacao/DFe.NET
Biblioteca para Geração de NFe(2.0, 3.10 e 4.0) e NFCe(3.10 e 4.0) e consumo dos serviços necessários à sua manutenção, conforme descritos em http://www.nfe.fazenda.gov.br/portal/principal.aspx
Version Downloads Last updated
2025.1.6 1,299 3/13/2025
2025.1.5 19,732 3/3/2025
2025.1.4 9,466 2/28/2025
2025.1.3 22,535 2/20/2025
2025.1.2 36,309 2/8/2025
2025.1.1 20,401 2/3/2025
2025.1.0 9,745 2/2/2025
2025.1.0-rc0 2,103 1/24/2025
2025.1.0-alpha0 8,348 12/4/2024
2024.12.3 50,629 1/24/2025
2024.12.2 91,504 1/4/2025
2024.12.1 92,710 12/9/2024
2024.12.0 32,073 12/4/2024
2024.12.0-rc3 2,479 11/29/2024
2024.12.0-rc2 2,220 11/22/2024
2024.12.0-rc1 189 11/22/2024
2024.12.0-rc0 5,322 11/18/2024
2024.10.4 77,351 11/22/2024
2024.10.3 96,642 11/8/2024
2024.10.2 129,764 10/24/2024
2024.10.1 93,336 10/14/2024
2024.10.0 53,849 10/4/2024
2024.10.0-rc4 4,237 9/26/2024
2024.10.0-rc3 12,314 9/17/2024
2024.10.0-rc2 423 9/16/2024
2024.10.0-rc1 322 9/13/2024
2024.10.0-rc0 6,237 9/4/2024
2024.7.3 223,947 8/27/2024
2024.7.2 168,548 8/1/2024
2024.7.1 83,308 7/22/2024
2024.7.0 47,982 7/15/2024
2024.7.0-rc0 3,122 7/4/2024
2024.6.4 97,018 6/25/2024
2024.6.3 908 6/25/2024
2024.6.2 41,628 6/20/2024
2024.6.1 26,824 6/15/2024
2024.6.0 66,263 6/11/2024
2024.3.10 98,436 5/25/2024
2024.3.9 13,992 5/23/2024
2024.3.8 800 5/23/2024
2024.3.7 28,652 5/20/2024
2024.3.6 44,486 5/14/2024
2024.3.5 30,372 5/12/2024
2024.3.4 35,457 5/6/2024
2024.3.3 13,024 5/2/2024
2024.3.2 50,051 4/25/2024
2024.3.1 43,184 4/22/2024
2024.3.0 88,532 4/12/2024
2024.3.0-rc2 4,962 3/30/2024
2024.3.0-rc1 261 3/29/2024
2024.3.0-rc 650 3/27/2024
2024.3.0-beta1 2,929 3/18/2024
2024.3.0-beta 4,043 2/29/2024
2024.3.0-alpha 1,786 2/15/2024
2023.12.6 345,974 2/21/2024
2023.12.5 83,833 2/7/2024
2023.12.4 176,070 1/15/2024
2023.12.3 22,708 1/12/2024
2023.12.2 75,942 1/1/2024
2023.12.1 82,539 12/15/2023
2023.12.0 58,323 12/3/2023
2023.10.2 95,429 11/13/2023
2023.10.1 51,774 10/31/2023
2023.10.0 35,220 10/23/2023
2023.10.0-alpha0 392 10/13/2023
2023.9.1 53,937 10/6/2023
2023.9.0 41,849 9/25/2023
2023.6.3 163,651 8/27/2023
2023.6.2 931 8/26/2023
2023.6.1 120,176 7/20/2023
2023.6.0 90,600 6/28/2023
2023.5.3 112,033 6/12/2023
2023.5.2 69,829 5/31/2023
2023.5.1 31,721 5/22/2023
2023.5.0 13,155 5/15/2023
2023.4.2 15,604 5/9/2023
2023.4.1 5,481 5/4/2023
2023.4.0 2,301 5/4/2023
2022.12.15 389,829 2/7/2024
2022.12.14 43,361 1/12/2024
2022.12.13 11,224 1/1/2024
2022.12.12 27,505 12/15/2023
2022.12.11 29,390 12/3/2023
2022.12.10 13,679 11/13/2023
2022.12.9 3,784 10/31/2023
2022.12.8 34,499 10/23/2023
2022.12.7 107,713 10/6/2023
2022.12.6 517,621 5/9/2023
2022.12.5 165,697 4/27/2023
2022.12.4 39,156 4/22/2023
2022.12.3 79,551 4/16/2023
2022.12.2 356,193 3/12/2023
2022.12.1 636,807 1/13/2023
2022.12.0 169,128 12/14/2022
2022.11.0 414,911 11/5/2022
2022.11.0-alpha1 379 11/1/2022
2022.11.0-alpha0 341 10/28/2022
2022.9.1 100,309 10/15/2022
2022.9.0 151,516 9/18/2022
2022.9.0-alpha1 325 9/16/2022
2022.8.2 175,539 8/21/2022
2022.8.1 21,062 8/19/2022
2022.8.0 111,218 8/15/2022
2022.6.3 58,746 7/18/2022
2022.6.2 145,166 6/22/2022
2022.6.1 23,905 6/12/2022
2022.6.0 170,519 6/12/2022
2022.6.0-prerelease 1,842 5/30/2022
2022.5.0 298,249 5/9/2022
2022.4.1 120,565 4/8/2022
2022.4.0 75,506 4/4/2022
2022.4.0-alpha1 363 3/27/2022
2022.4.0-alpha0 331 3/27/2022
2022.3.1 102,608 3/15/2022
2022.3.0 2,865 3/14/2022
2022.2.7 1,793 3/12/2022
2022.2.6 6,642 3/8/2022
2022.2.5 21,315 2/18/2022
2022.2.4 737 2/18/2022
2022.2.3 11,723 2/7/2022
2022.2.2 2,089 2/1/2022
2022.2.1 1,736 1/30/2022
2022.2.0 1,937 1/29/2022
2022.2.0-beta1 357 1/24/2022
2022.1.0 28,981 1/10/2022
2022.1.0-beta5 1,009 1/7/2022
2022.1.0-beta4 366 1/6/2022
2022.1.0-beta3 337 1/5/2022
2022.1.0-beta2 355 1/5/2022
2022.1.0-beta1 360 1/3/2022
2022.1.0-beta0 334 12/30/2021
2022.1.0-alpha0 391 12/30/2021 2022.1.0-alpha0 is deprecated because it is no longer maintained.
2021.12.0 34,065 12/6/2021
2021.12.0-alpha1 1,184 11/29/2021
2021.12.0-alpha0 411 11/18/2021
2021.11.4 23,786 11/14/2021
2021.11.3 4,999 11/7/2021
2021.11.0-beta3 423 11/3/2021
2021.11.0-beta2 454 10/28/2021
2021.11.0-beta 487 10/23/2021
2021.10.1 10,225 9/30/2021
2021.10.0 644 9/30/2021
2021.10.0-beta.2 297 9/14/2021
2021.10.0-beta 441 9/13/2021
2021.9.3 7,294 9/12/2021
2021.9.2 758 9/1/2021
2021.9.1 592 9/1/2021
2021.9.0 557 8/30/2021
2021.8.0 2,527 8/2/2021
2021.5.2 3,649 5/5/2021
2021.4.0 802 4/2/2021
2021.3.1 7,162 3/1/2021
2021.3.0 617 3/1/2021
2021.2.0 665 2/8/2021
2021.1.0 727 1/4/2021
2020.11.0 12,269 11/1/2020

Version 2022.12.0:
Feature: implemented LetterSpacing property for the Text element
Improvement: the Text element API accepts now only string values, objects are not automatically converted anymore
Fix: the Alignment element incorrectly limits size of its child when only one axis is set (horizontal or vertical)
Maintenance: Updated SkiaSharp dependency to 2.88.3

This release was possible thanks to enormous help of AntonyCorbett, thank you!

Version 2022.12.1:
Fixed: loading fonts from embedded resource via the FontManager.RegisterFontFromEmbeddedResource method
Fixed: better layout calculation stability for the Column element
Improvement: exposed missing API method for the Dynamic component, enabling applying more advanced optimizations
Improvement: better API documentation for the Settings.DocumentLayoutExceptionThreshold property

Version 2022.12.2:
Performance improvements in various areas
Text rendering stability improvements
Fixed: the Settings.CheckIfAllTextGlyphsAreAvailable setting does not work correctly

Version 2022.12.3:
Fix: inconsistent text height when using multiple lines with different TextStyles
Improvement: added validation for color arguments
Fix: the inlined element is shown only once in the header but should be repeated on each page

Version 2022.12.4:
Fix: the TextStyle.Fallback property incorrectly inherits parent's and global properties
Improvement: updated the CreateNotMatchingFontException message to mention that the glyph checking operation can be disabled with the Settings.CheckIfAllTextGlyphsAreAvailable setting

Version 2022.12.6:
Fix: fixed the rendering order of table cells in certain scenarios

Version 2022.12.7:
- Text rendering enhancement: a fake underline is drawn when the font typeface lacks an underline effect configuration or it is unavailable on runtime operating system
- Text rendering enhancement: a fake strikethrough is drawn when the font typeface lacks a strikethrough effect configuration or it is unavailable on runtime operating system
- Text rendering enhancement: a fake skew operation is applied to mimic an italic effect when the provided font lacks an italic variant
- Text rendering enhancement: a fake bold effect is applied when the font doesn't offer variants of higher weight

Version 2022.12.8:
- Updated SkiaSharp dependency from 2.88.3 to 2.88.6
- Updated QuestPDF Previewer dependencies: from Avalonia 0.10.X to 11.0.X

Version 2022.12.9:
- Enhanced developer experience by refining the accuracy of the exception message thrown when native SkiaSharp dependencies are unavailable in the runtime environment.

Version 2022.12.10
- Enhanced SkiaSharp native dependency detection for increased compatibility.
- Fixed rare instances of text rendering inaccurately due to cache-related faults.
- Fixed a rare problem where the Row element does not always respect layout issues in its children.

Version 2022.12.11
- Back-ported feature as part of extended support: simplified development loop by introducing cross-platform methods GeneratePdfAndShow() and GenerateXpsAndShow()
- Back-ported community-developed feature: added functionality to specify unit types for the Spacing property in the Row element, improving Fluent API consistency (by @sclarke81)
- Back-ported community-developed improvement: integrated CancellationToken support in the ShowInPreviewer method (by @marcmognol)
- Back-ported community-developed improvement: simplified DynamicComponent usage by introducing a state-less component model (by @bennetbo)

Version 2022.12.12
- Fixed: table layout renders incorrectly if one of its cells spans at least three pages