QuestPDF 2021.12.0-alpha1
See the version list below for details.
dotnet add package QuestPDF --version 2021.12.0-alpha1
NuGet\Install-Package QuestPDF -Version 2021.12.0-alpha1
<PackageReference Include="QuestPDF" Version="2021.12.0-alpha1" />
<PackageVersion Include="QuestPDF" Version="2021.12.0-alpha1" />
<PackageReference Include="QuestPDF" />
paket add QuestPDF --version 2021.12.0-alpha1
#r "nuget: QuestPDF, 2021.12.0-alpha1"
#addin nuget:?package=QuestPDF&version=2021.12.0-alpha1&prerelease
#tool nuget:?package=QuestPDF&version=2021.12.0-alpha1&prerelease
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.
Features
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)
{
container
.Page(page =>
{
page.Margin(50);
page.Header().Element(ComposeHeader);
page.Content().Element(ComposeContent);
page.Footer().AlignCenter().Text(x =>
{
x.CurrentPageNumber();
x.Span(" / ");
x.TotalPages();
});
});
}
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());
text.Span($"{Model.IssueDate:d}");
});
stack.Item().Text(text =>
{
text.Span("Due date: ", TextStyle.Default.SemiBold());
text.Span($"{Model.DueDate:d}");
});
});
row.ConstantColumn(100).Height(50).Placeholder();
});
}
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.Spacing(20);
column.Item().Row(row =>
{
row.RelativeColumn().Component(new AddressComponent("From", Model.SellerAddress));
row.ConstantColumn(50);
row.RelativeColumn().Component(new AddressComponent("For", Model.CustomerAddress));
});
column.Item().Element(ComposeTable);
var totalPrice = Model.Items.Sum(x => x.Price * x.Quantity);
column
.Item()
.PaddingRight(5)
.AlignRight()
.Text($"Grand total: {totalPrice}$", TextStyle.Default.SemiBold());
if (!string.IsNullOrWhiteSpace(Model.Comments))
column.Item().PaddingTop(25).Element(ComposeComments);
});
}
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
decoration
.Content()
.Stack(column =>
{
foreach (var item in Model.Items)
{
column
.Item()
.ShowEntire()
.BorderBottom(1)
.BorderColor(Colors.Grey.Lighten2)
.Padding(5)
.Row(row =>
{
row.ConstantColumn(25).Text(Model.Items.IndexOf(item) + 1);
row.RelativeColumn(3).Text(item.Name);
row.RelativeColumn().AlignRight().Text($"{item.Price}$");
row.RelativeColumn().AlignRight().Text(item.Quantity);
row.RelativeColumn().AlignRight().Text($"{item.Price * item.Quantity}$");
});
}
});
});
}
void ComposeComments(IContainer container)
{
container.ShowEntire().Background(Colors.Grey.Lighten3).Padding(10).Stack(message =>
{
message.Spacing(5);
message.Item().Text("Comments", TextStyle.Default.Size(14).SemiBold());
message.Item().Text(Model.Comments);
});
}
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 =>
{
column.Spacing(5);
column
.Item()
.BorderBottom(1)
.PaddingBottom(5)
.Text(Title, TextStyle.Default.SemiBold());
column.Item().Text(Address.CompanyName);
column.Item().Text(Address.Street);
column.Item().Text($"{Address.City}, {Address.State}");
column.Item().Text(Address.Email);
column.Item().Text(Address.Phone);
});
}
}
Product | Versions 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. |
.NET Core | netcoreapp2.0 is compatible. 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 is compatible. 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. |
NuGet packages (43)
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 |
|
Verify.QuestPDF
Extends Verify (https://github.com/VerifyTests/Verify) to allow verification via QuestPDF. |
|
QuestPDF.Markdown
QuestPDF.Markdown is an open-source helper library that allows rendering markdown into a QuestPDF document |
GitHub repositories (16)
Showing the top 16 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
|
|
NickvisionApps/Denaro
Manage your personal finances
|
|
axzxs2001/Asp.NetCoreExperiment
原来所有项目都移动到**OleVersion**目录下进行保留。新的案例装以.net 5.0为主,一部分对以前案例进行升级,一部分将以前的工作经验总结出来,以供大家参考!
|
|
QuestPDF/QuestPDF-ExampleInvoice
|
|
YSGStudyHards/DotNetExercises
⚔【DotNetGuide专栏C#/.NET/.NET Core编程技巧练习集】C#/.NET/.NET Core编程常用语法、算法、技巧、中间件、类库、工作业务实操练习集,配套详细的文章教程讲解,助你快速掌握C#/.NET/.NET Core中各种编程常用语法、算法、技巧、中间件、类库、工作业务实操等等。
|
|
Corsinvest/cv4pve-admin
Corsinvest for Proxmox VE Web Admin Clusters - vCenter but for Proxmoxm VE
|
|
BoletoNet/BoletoNetCore
Versão do BoletoNet para .NET Core
|
|
zmrid/iMES-Factory
iMES工厂管家——您的新一代工厂助手。演示地址:https://imes.625sc.com。 一款基于.NetCore3.1和Vue3的MES管理系统。项目亮点:模版打印,Excel模版导出,自定义实体扩展,移动端精美设计,大屏设计等功能。
|
|
markjprice/apps-services-net8
Repository for the Packt Publishing book titled "Apps and Services with .NET 8" by Mark J. Price
|
|
kyoyama-kazusa/Sudoku
A sudoku solver using brute forces and logical techniques.
|
|
bingbing-gui/AspNetCore-Skill
.NET 9 打造的 ASP.NET Core 学习仓库,涵盖常用技术点 + 实战示例,配套优质开源库,欢迎 star! Learn ASP.NET Core with .NET 9 — real-world samples, essential features, and awesome libraries. Star it if you like!
|
|
Relorer/HTMLToQPDF
HTMLToQPDF is an extension for QuestPDF that allows to generate PDF from HTML
|
Version | Downloads | Last updated | |
---|---|---|---|
2025.4.0 | 2,197 | 4/7/2025 | |
2025.1.7 | 26,141 | 3/21/2025 | |
2025.1.6 | 21,219 | 3/13/2025 | |
2025.1.5 | 48,227 | 3/3/2025 | |
2025.1.4 | 15,024 | 2/28/2025 | |
2025.1.3 | 32,155 | 2/20/2025 | |
2025.1.2 | 45,298 | 2/8/2025 | |
2025.1.1 | 26,370 | 2/3/2025 | |
2025.1.0 | 11,576 | 2/2/2025 | |
2025.1.0-rc0 | 2,256 | 1/24/2025 | |
2025.1.0-alpha0 | 9,121 | 12/4/2024 | |
2024.12.3 | 66,049 | 1/24/2025 | |
2024.12.2 | 108,251 | 1/4/2025 | |
2024.12.1 | 104,747 | 12/9/2024 | |
2024.12.0 | 35,682 | 12/4/2024 | |
2024.12.0-rc3 | 2,852 | 11/29/2024 | |
2024.12.0-rc2 | 2,463 | 11/22/2024 | |
2024.12.0-rc1 | 202 | 11/22/2024 | |
2024.12.0-rc0 | 6,291 | 11/18/2024 | |
2024.10.4 | 86,469 | 11/22/2024 | |
2024.10.3 | 105,019 | 11/8/2024 | |
2024.10.2 | 140,755 | 10/24/2024 | |
2024.10.1 | 102,591 | 10/14/2024 | |
2024.10.0 | 57,200 | 10/4/2024 | |
2024.10.0-rc4 | 4,652 | 9/26/2024 | |
2024.10.0-rc3 | 13,116 | 9/17/2024 | |
2024.10.0-rc2 | 431 | 9/16/2024 | |
2024.10.0-rc1 | 323 | 9/13/2024 | |
2024.10.0-rc0 | 6,461 | 9/4/2024 | |
2024.7.3 | 236,822 | 8/27/2024 | |
2024.7.2 | 181,002 | 8/1/2024 | |
2024.7.1 | 87,007 | 7/22/2024 | |
2024.7.0 | 50,287 | 7/15/2024 | |
2024.7.0-rc0 | 3,427 | 7/4/2024 | |
2024.6.4 | 101,832 | 6/25/2024 | |
2024.6.3 | 998 | 6/25/2024 | |
2024.6.2 | 46,879 | 6/20/2024 | |
2024.6.1 | 27,654 | 6/15/2024 | |
2024.6.0 | 69,114 | 6/11/2024 | |
2024.3.10 | 102,051 | 5/25/2024 | |
2024.3.9 | 14,745 | 5/23/2024 | |
2024.3.8 | 891 | 5/23/2024 | |
2024.3.7 | 30,377 | 5/20/2024 | |
2024.3.6 | 46,778 | 5/14/2024 | |
2024.3.5 | 31,810 | 5/12/2024 | |
2024.3.4 | 37,070 | 5/6/2024 | |
2024.3.3 | 13,380 | 5/2/2024 | |
2024.3.2 | 51,869 | 4/25/2024 | |
2024.3.1 | 45,025 | 4/22/2024 | |
2024.3.0 | 94,900 | 4/12/2024 | |
2024.3.0-rc2 | 5,038 | 3/30/2024 | |
2024.3.0-rc1 | 261 | 3/29/2024 | |
2024.3.0-rc | 650 | 3/27/2024 | |
2024.3.0-beta1 | 2,989 | 3/18/2024 | |
2024.3.0-beta | 4,152 | 2/29/2024 | |
2024.3.0-alpha | 1,796 | 2/15/2024 | |
2023.12.6 | 359,068 | 2/21/2024 | |
2023.12.5 | 85,709 | 2/7/2024 | |
2023.12.4 | 182,690 | 1/15/2024 | |
2023.12.3 | 22,891 | 1/12/2024 | |
2023.12.2 | 79,610 | 1/1/2024 | |
2023.12.1 | 84,648 | 12/15/2023 | |
2023.12.0 | 59,577 | 12/3/2023 | |
2023.10.2 | 98,062 | 11/13/2023 | |
2023.10.1 | 53,290 | 10/31/2023 | |
2023.10.0 | 35,764 | 10/23/2023 | |
2023.10.0-alpha0 | 392 | 10/13/2023 | |
2023.9.1 | 55,856 | 10/6/2023 | |
2023.9.0 | 42,677 | 9/25/2023 | |
2023.6.3 | 166,644 | 8/27/2023 | |
2023.6.2 | 983 | 8/26/2023 | |
2023.6.1 | 123,611 | 7/20/2023 | |
2023.6.0 | 94,033 | 6/28/2023 | |
2023.5.3 | 122,778 | 6/12/2023 | |
2023.5.2 | 71,405 | 5/31/2023 | |
2023.5.1 | 32,409 | 5/22/2023 | |
2023.5.0 | 13,251 | 5/15/2023 | |
2023.4.2 | 16,034 | 5/9/2023 | |
2023.4.1 | 5,555 | 5/4/2023 | |
2023.4.0 | 2,494 | 5/4/2023 | |
2022.12.15 | 423,422 | 2/7/2024 | |
2022.12.14 | 46,596 | 1/12/2024 | |
2022.12.13 | 11,451 | 1/1/2024 | |
2022.12.12 | 28,238 | 12/15/2023 | |
2022.12.11 | 31,749 | 12/3/2023 | |
2022.12.10 | 13,925 | 11/13/2023 | |
2022.12.9 | 3,825 | 10/31/2023 | |
2022.12.8 | 36,820 | 10/23/2023 | |
2022.12.7 | 109,686 | 10/6/2023 | |
2022.12.6 | 529,607 | 5/9/2023 | |
2022.12.5 | 168,788 | 4/27/2023 | |
2022.12.4 | 41,091 | 4/22/2023 | |
2022.12.3 | 80,020 | 4/16/2023 | |
2022.12.2 | 363,633 | 3/12/2023 | |
2022.12.1 | 647,564 | 1/13/2023 | |
2022.12.0 | 170,914 | 12/14/2022 | |
2022.11.0 | 419,464 | 11/5/2022 | |
2022.11.0-alpha1 | 382 | 11/1/2022 | |
2022.11.0-alpha0 | 352 | 10/28/2022 | |
2022.9.1 | 101,090 | 10/15/2022 | |
2022.9.0 | 153,861 | 9/18/2022 | |
2022.9.0-alpha1 | 328 | 9/16/2022 | |
2022.8.2 | 177,703 | 8/21/2022 | |
2022.8.1 | 21,069 | 8/19/2022 | |
2022.8.0 | 112,591 | 8/15/2022 | |
2022.6.3 | 59,319 | 7/18/2022 | |
2022.6.2 | 151,080 | 6/22/2022 | |
2022.6.1 | 24,069 | 6/12/2022 | |
2022.6.0 | 170,531 | 6/12/2022 | |
2022.6.0-prerelease | 1,862 | 5/30/2022 | |
2022.5.0 | 299,293 | 5/9/2022 | |
2022.4.1 | 121,167 | 4/8/2022 | |
2022.4.0 | 76,460 | 4/4/2022 | |
2022.4.0-alpha1 | 368 | 3/27/2022 | |
2022.4.0-alpha0 | 335 | 3/27/2022 | |
2022.3.1 | 103,169 | 3/15/2022 | |
2022.3.0 | 2,894 | 3/14/2022 | |
2022.2.7 | 1,798 | 3/12/2022 | |
2022.2.6 | 6,655 | 3/8/2022 | |
2022.2.5 | 21,489 | 2/18/2022 | |
2022.2.4 | 741 | 2/18/2022 | |
2022.2.3 | 11,755 | 2/7/2022 | |
2022.2.2 | 2,096 | 2/1/2022 | |
2022.2.1 | 1,799 | 1/30/2022 | |
2022.2.0 | 1,943 | 1/29/2022 | |
2022.2.0-beta1 | 368 | 1/24/2022 | |
2022.1.0 | 29,398 | 1/10/2022 | |
2022.1.0-beta5 | 1,016 | 1/7/2022 | |
2022.1.0-beta4 | 370 | 1/6/2022 | |
2022.1.0-beta3 | 341 | 1/5/2022 | |
2022.1.0-beta2 | 359 | 1/5/2022 | |
2022.1.0-beta1 | 364 | 1/3/2022 | |
2022.1.0-beta0 | 341 | 12/30/2021 | |
2022.1.0-alpha0 | 399 | 12/30/2021 | |
2021.12.0 | 34,289 | 12/6/2021 | |
2021.12.0-alpha1 | 1,189 | 11/29/2021 | |
2021.12.0-alpha0 | 415 | 11/18/2021 | |
2021.11.4 | 23,937 | 11/14/2021 | |
2021.11.3 | 5,018 | 11/7/2021 | |
2021.11.0-beta3 | 427 | 11/3/2021 | |
2021.11.0-beta2 | 458 | 10/28/2021 | |
2021.11.0-beta | 491 | 10/23/2021 | |
2021.10.1 | 10,258 | 9/30/2021 | |
2021.10.0 | 650 | 9/30/2021 | |
2021.10.0-beta.2 | 302 | 9/14/2021 | |
2021.10.0-beta | 445 | 9/13/2021 | |
2021.9.3 | 7,452 | 9/12/2021 | |
2021.9.2 | 767 | 9/1/2021 | |
2021.9.1 | 599 | 9/1/2021 | |
2021.9.0 | 561 | 8/30/2021 | |
2021.8.0 | 2,537 | 8/2/2021 | |
2021.5.2 | 3,697 | 5/5/2021 | |
2021.4.0 | 819 | 4/2/2021 | |
2021.3.1 | 7,172 | 3/1/2021 | |
2021.3.0 | 625 | 3/1/2021 | |
2021.2.0 | 674 | 2/8/2021 | |
2021.1.0 | 741 | 1/4/2021 | |
2020.11.0 | 12,456 | 11/1/2020 |
- Added support for generating documents in the XPS file format.