QuestPDF 2021.12.0

.NET Core 2.0 .NET Standard 2.0 .NET Framework 4.6.2
There is a newer version of this package available.
See the version list below for details.
dotnet add package QuestPDF --version 2021.12.0
NuGet\Install-Package QuestPDF -Version 2021.12.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="QuestPDF" Version="2021.12.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add QuestPDF --version 2021.12.0
#r "nuget: QuestPDF, 2021.12.0"
#r directive can be used in F# Interactive, C# scripting and .NET Interactive. 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=2021.12.0

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

QuestPDF Overview

QuestPDF is an open-source, modern and battle-tested library that can help you with generating PDF documents by offering friendly, discoverable and predictable C# fluent API.


Rely on solid fundamentals - This library is created specifically for designing and arranging document layouts, with full paging support. Alternative solutions, such as HTML-based converters, are not designed for this purpose and therefore are often unpredictable and do not produce desired results.

Work with organized self-explanatory code - The entire process of implementing PDF document, takes place in your code. Free yourself from slow visual designers and strange technological limitations. Follow simple yet highly effective approaches to create maintainable, high-quality code.

Compose simple components into complex documents - Do you remember the feeling when your code just works? When your ideas are becoming real without any effort? Working with simple, easy to understand, self-explanatory and highly composable layout elements is the key here!

Create and reuse components - Feel no fear of complex documents! Create custom, reusable components and divide the document's layout into easy to maintain pieces. Inject data to customize content and use slots to enhance composability. Decide how complex approaches your solution needs and follow the best path.

Prototype with ease - We understand that document generation is often tricky and require multiple iterations. The library offers additional prototyping tools such as random text generator or image placeholder element. By following best practices, you can develop a document without having data.

Enjoy fast PDF generation - QuestPDF is created upon SkiaSharp, a well-known graphical library, and converts your data into PDF documents. It offers a highly optimized layouting engine capable of generating over 1000 PDF files per minute per core. The entire process is thread-safe.

Learning resources

Release notes and roadmap - everything that is planned for future library iterations, description of new features and information about potential breaking changes.

Getting started tutorial - a short and easy to follow tutorial showing how to design an invoice document under 200 lines of code.

API Reference - a detailed description of behavior of all available components and how to use them with C# Fluent API.

Patterns and practices - everything that may help you designing great reports and reusable code that is easy to maintain.

Example invoice

Do you believe that creating a complete invoice document can take less than 200 lines of code? We have prepared for you a step-by-step instruction that shows every detail of this implementation and describes the best patterns and practices.

For tutorial, documentation and API reference, please visit the QuestPDF documentation.


Here you can find an example code showing how easy is to write and understand the fluent API.

General document structure with header, content and footer:

public void Compose(IDocumentContainer container)
        .Page(page =>
            page.Footer().AlignCenter().Text(x =>
                x.Span(" / ");

The header area consists of basic invoice information along with a logo placeholder.

void ComposeHeader(IContainer container)
    var titleTextStyle = TextStyle.Default.Size(20).SemiBold().Color(Colors.Blue.Medium);
    container.Row(row =>
            stack.Item().Text($"Invoice #{Model.InvoiceNumber}", titleStyle);

            stack.Item().Text(text =>
                text.Span("Issue date: ", TextStyle.Default.SemiBold());

            stack.Item().Text(text =>
                text.Span("Due date: ", TextStyle.Default.SemiBold());

Implementation of the content area that contains seller and customer details, then listing of all bought products, then a comments section.

void ComposeContent(IContainer container)
    container.PaddingVertical(40).Stack(column => 
        column.Item().Row(row =>
            row.RelativeColumn().Component(new AddressComponent("From", Model.SellerAddress));
            row.RelativeColumn().Component(new AddressComponent("For", Model.CustomerAddress));


        var totalPrice = Model.Items.Sum(x => x.Price * x.Quantity);
            .Text($"Grand total: {totalPrice}$", TextStyle.Default.SemiBold());

        if (!string.IsNullOrWhiteSpace(Model.Comments))

The table and comments codes are extracted into separate methods to increase clarity:

void ComposeTable(IContainer container)
    var headerStyle = TextStyle.Default.SemiBold();
    container.Decoration(decoration =>
        // header
        decoration.Header().BorderBottom(1).Padding(5).Row(row => 
            row.ConstantColumn(25).Text("#", headerStyle);
            row.RelativeColumn(3).Text("Product", headerStyle);
            row.RelativeColumn().AlignRight().Text("Unit price", headerStyle);
            row.RelativeColumn().AlignRight().Text("Quantity", headerStyle);
            row.RelativeColumn().AlignRight().Text("Total", headerStyle);

        // content
            .Stack(column =>
                foreach (var item in Model.Items)
                    .Row(row => 
                        row.ConstantColumn(25).Text(Model.Items.IndexOf(item) + 1);
                        row.RelativeColumn().AlignRight().Text($"{item.Price * item.Quantity}$");
void ComposeComments(IContainer container)
    container.ShowEntire().Background(Colors.Grey.Lighten3).Padding(10).Stack(message => 
        message.Item().Text("Comments", TextStyle.Default.Size(14).SemiBold());

The address details section is implemented using components. This way the code can be easily reused for both seller and customer:

public class AddressComponent : IComponent
    private string Title { get; }
    private Address Address { get; }

    public AddressComponent(string title, Address address)
        Title = title;
        Address = address;
    public void Compose(IContainer container)
        container.ShowEntire().Stack(column =>

                .Text(Title, TextStyle.Default.SemiBold());
            column.Item().Text($"{Address.City}, {Address.State}");
Product Versions
.NET net5.0 net5.0-windows net6.0 net6.0-android net6.0-ios net6.0-maccatalyst net6.0-macos net6.0-tvos net6.0-windows
.NET Core netcoreapp2.0 netcoreapp2.1 netcoreapp2.2 netcoreapp3.0 netcoreapp3.1
.NET Standard netstandard2.0 netstandard2.1
.NET Framework net461 net462 net463 net47 net471 net472 net48
MonoAndroid monoandroid
MonoMac monomac
MonoTouch monotouch
Tizen tizen40 tizen60
Xamarin.iOS xamarinios
Xamarin.Mac xamarinmac
Xamarin.TVOS xamarintvos
Xamarin.WatchOS xamarinwatchos
Compatible target framework(s)
Additional computed target framework(s)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (9)

Showing the top 5 NuGet packages that depend on QuestPDF:

Package Downloads

Package Description


A2v10 Platform PDF report

Verify.QuestPDF The ID prefix of this package has been reserved for one of the owners of this package by

Extends Verify ( to allow verification via QuestPDF.


Package Description


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

GitHub repositories (4)

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

Repository Stars
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.
原来所有项目都移动到**OleVersion**目录下进行保留。新的案例装以.net 5.0为主,一部分对以前案例进行升级,一部分将以前的工作经验总结出来,以供大家参考!
Versão do BoletoNet para .NET Core
Version Downloads Last updated
2022.11.0 26,603 11/5/2022
2022.11.0-alpha1 62 11/1/2022
2022.11.0-alpha0 47 10/28/2022
2022.9.1 23,639 10/15/2022
2022.9.0 28,855 9/18/2022
2022.9.0-alpha1 66 9/16/2022
2022.8.2 38,249 8/21/2022
2022.8.1 3,271 8/19/2022
2022.8.0 10,026 8/15/2022
2022.6.3 27,679 7/18/2022
2022.6.2 42,795 6/22/2022
2022.6.1 11,943 6/12/2022
2022.6.0 30,179 6/12/2022
2022.6.0-prerelease 1,146 5/30/2022
2022.5.0 125,313 5/9/2022
2022.4.1 27,366 4/8/2022
2022.4.0 19,992 4/4/2022
2022.4.0-alpha1 105 3/27/2022
2022.4.0-alpha0 73 3/27/2022
2022.3.1 61,781 3/15/2022
2022.3.0 1,242 3/14/2022
2022.2.7 1,120 3/12/2022
2022.2.6 4,985 3/8/2022
2022.2.5 10,730 2/18/2022
2022.2.4 200 2/18/2022
2022.2.3 8,648 2/7/2022
2022.2.2 974 2/1/2022
2022.2.1 813 1/30/2022
2022.2.0 803 1/29/2022
2022.2.0-beta1 100 1/24/2022
2022.1.0 12,379 1/10/2022
2022.1.0-beta5 609 1/7/2022
2022.1.0-beta4 101 1/6/2022
2022.1.0-beta3 98 1/5/2022
2022.1.0-beta2 92 1/5/2022
2022.1.0-beta1 97 1/3/2022
2022.1.0-beta0 97 12/30/2021
2022.1.0-alpha0 119 12/30/2021
2021.12.0 16,623 12/6/2021
2021.12.0-alpha1 921 11/29/2021
2021.12.0-alpha0 157 11/18/2021
2021.11.4 13,435 11/14/2021
2021.11.3 3,156 11/7/2021
2021.11.0-beta3 152 11/3/2021
2021.11.0-beta2 202 10/28/2021
2021.11.0-beta 253 10/23/2021
2021.10.1 6,575 9/30/2021
2021.10.0 284 9/30/2021
2021.10.0-beta.2 158 9/14/2021
2021.10.0-beta 191 9/13/2021
2021.9.3 2,283 9/12/2021
2021.9.2 337 9/1/2021
2021.9.1 213 9/1/2021
2021.9.0 208 8/30/2021
2021.8.0 2,051 8/2/2021
2021.5.2 1,721 5/5/2021
2021.4.0 418 4/2/2021
2021.3.1 6,502 3/1/2021
2021.3.0 233 3/1/2021
2021.2.0 253 2/8/2021
2021.1.0 285 1/4/2021
2020.11.0 3,469 11/1/2020

- Improved debugging experience for layout-related exceptions. To make the library predictable, it is (by design) very strict about layouting rules and throws an exception when a constraint cannot be met. In this release, each exception contains an element stack that contains all information needed to identify the issue. By default, this feature is enabled only when debugger is attached.
- Improved layouting algorithm performance by introducing additional caching layer. This cache reduces the layouting time by half. By default, this feature is enabled only when debugger is not attached (mostly release mode).
- Reduced GA pressure put by the layouting algorithm. Previously, every element measurement operation was represented by an object and the paging support was done via class hierarchy. New solution uses structs (which are value-types) and enums. This also makes the code more readable and easier to follow.
- Added support for generating XPS files which are easier to print in the Windows environment. This was possible due to existing support in SkiaSharp. This change was proposed by **sbrkich**, thank you!