【愚公系列】2022年10月 .NET CORE工具案例-.NET Core使用QuestPDF

2023-11-04 09:59

本文主要是介绍【愚公系列】2022年10月 .NET CORE工具案例-.NET Core使用QuestPDF,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、.NET Core使用QuestPDF
    • 1.Nuget安装包
    • 2.官方案例
    • 3.发票案例
      • 3.1 定义模型类InvoiceModel
      • 3.2 InvoiceDocumentDataSource数据生成
      • 3.3 InvoiceDocument 发票文档
      • 3.4 生成发票


前言

QuestPDF是一个用于生成PDF文档的open-source.NET库。

它提供了一个布局引擎,设计时考虑了完整的分页支持。文档由许多简单元素组成(例如边框、背景、图像、文本、填充、表格、网格等),这些元素组合在一起以创建更复杂的结构。这样,作为一名开发人员,您可以理解每个元素的行为,并满怀信心地使用它们。此外,文档及其所有元素都支持分页功能。例如,一个元素可以移动到下一页(如果没有足够的空间),甚至可以像表的行一样在页面之间拆分。

与其他库不同,它不依赖HTML-to-PDF转换,在许多情况下,这种转换不可靠。相反,它实现了自己的布局引擎,该引擎经过优化以覆盖所有paging-related需求。

github文档地址:https://github.com/QuestPDF/QuestPDF
在这里插入图片描述

API文档地址:https://www.questpdf.com/api-reference/index
在这里插入图片描述

一、.NET Core使用QuestPDF

1.Nuget安装包

Install-Package QuestPDF

在这里插入图片描述

2.官方案例

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.PageColor(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");

在这里插入图片描述

3.发票案例

3.1 定义模型类InvoiceModel

//发票类
public class InvoiceModel
{//发票号public int InvoiceNumber { get; set; }//发布日期public DateTime IssueDate { get; set; }//到期日public DateTime DueDate { get; set; }//卖方地址public Address SellerAddress { get; set; }//顾客地址public Address CustomerAddress { get; set; }//订单项目public List<OrderItem> Items { get; set; }//评论public string Comments { get; set; }
}
//订单类
public class OrderItem
{//名称public string Name { get; set; }//价格public decimal Price { get; set; }//数量public int Quantity { get; set; }
}
//地址类
public class Address
{//公司地址public string CompanyName { get; set; }//街道public string Street { get; set; }//城市public string City { get; set; }//状态public string State { get; set; }//邮件public object Email { get; set; }//电话public string Phone { get; set; }
}

3.2 InvoiceDocumentDataSource数据生成

public static class InvoiceDocumentDataSource
{private static Random Random = new Random();public static InvoiceModel GetInvoiceDetails(){var items = Enumerable.Range(1, 25).Select(i => GenerateRandomOrderItem()).ToList();return new InvoiceModel{InvoiceNumber = Random.Next(1_000, 10_000),IssueDate = DateTime.Now,DueDate = DateTime.Now + TimeSpan.FromDays(14),SellerAddress = GenerateRandomAddress(),CustomerAddress = GenerateRandomAddress(),Items = items,Comments = Placeholders.Paragraph()};}private static OrderItem GenerateRandomOrderItem(){return new OrderItem{Name = Placeholders.Label(),Price = (decimal) Math.Round(Random.NextDouble() * 100, 2),Quantity = Random.Next(1, 10)};}private static Address GenerateRandomAddress(){return new Address{CompanyName = Placeholders.Name(),Street = Placeholders.Label(),City = Placeholders.Label(),State = Placeholders.Label(),Email = Placeholders.Email(),Phone = Placeholders.PhoneNumber() };}
}

3.3 InvoiceDocument 发票文档

using System.Linq;
using QuestPDF.Drawing;
using QuestPDF.Fluent;
using QuestPDF.Helpers;
using QuestPDF.Infrastructure;namespace QuestPDF.ExampleInvoice
{public class InvoiceDocument : IDocument{public InvoiceModel Model { get; }public InvoiceDocument(InvoiceModel model){Model = model;}//定义文档的元数据(创建日期,修改日期,作者等)public DocumentMetadata GetMetadata() => DocumentMetadata.Default;//发票模板public void Compose(IDocumentContainer container){container.Page(page =>{//页面间距page.Margin(50);//页面头page.Header().Element(ComposeHeader);// 页面内容page.Content().Element(ComposeContent);//1 / 2page.Footer().AlignCenter().Text(text =>{//当前页数text.CurrentPageNumber();//分割text.Span(" / ");//总页数text.TotalPages();});});}//发票头void ComposeHeader(IContainer container){container.Row(row =>{//其实row相当于列,Column相当于行row.RelativeItem().Column(Column =>{Column.Item().Text($"Invoice #{Model.InvoiceNumber}").FontSize(20).SemiBold().FontColor(Colors.Blue.Medium);Column.Item().Text(text =>{text.Span("Issue date: ").SemiBold();text.Span($"{Model.IssueDate:d}");});Column.Item().Text(text =>{text.Span("Due date: ").SemiBold();text.Span($"{Model.DueDate:d}");});});//宽100,高50的图片row.ConstantItem(100).Height(50).Placeholder();});}//发票体void ComposeContent(IContainer container){//其实row相当于列,Column相当于行container.PaddingVertical(40).Column(column => {column.Spacing(20);//交易方信息column.Item().Row(row =>{row.RelativeItem().Component(new AddressComponent("From", Model.SellerAddress));row.ConstantItem(50);row.RelativeItem().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}$").SemiBold();if (!string.IsNullOrWhiteSpace(Model.Comments))column.Item().PaddingTop(25).Element(ComposeComments);});}//发票表格void ComposeTable(IContainer container){var headerStyle = TextStyle.Default.SemiBold();container.Table(table =>{table.ColumnsDefinition(columns =>{columns.ConstantColumn(25);columns.RelativeColumn(3);columns.RelativeColumn();columns.RelativeColumn();columns.RelativeColumn();});table.Header(header =>{header.Cell().Text("#");header.Cell().Text("Product").Style(headerStyle);header.Cell().AlignRight().Text("Unit price").Style(headerStyle);header.Cell().AlignRight().Text("Quantity").Style(headerStyle);header.Cell().AlignRight().Text("Total").Style(headerStyle);header.Cell().ColumnSpan(5).PaddingTop(5).BorderBottom(1).BorderColor(Colors.Black);});foreach (var item in Model.Items){table.Cell().Element(CellStyle).Text(Model.Items.IndexOf(item) + 1);table.Cell().Element(CellStyle).Text(item.Name);table.Cell().Element(CellStyle).AlignRight().Text($"{item.Price}$");table.Cell().Element(CellStyle).AlignRight().Text(item.Quantity);table.Cell().Element(CellStyle).AlignRight().Text($"{item.Price * item.Quantity}$");static IContainer CellStyle(IContainer container) => container.BorderBottom(1).BorderColor(Colors.Grey.Lighten2).PaddingVertical(5);}});}//发票评论void ComposeComments(IContainer container){container.ShowEntire().Background(Colors.Grey.Lighten3).Padding(10).Column(column => {column.Spacing(5);column.Item().Text("Comments").FontSize(14).SemiBold();column.Item().Text(Model.Comments);});}}//地址组件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().Column(column =>{column.Spacing(2);//公司方向(销售和客户)column.Item().Text(Title).SemiBold();//画线column.Item().PaddingBottom(5).LineHorizontal(1); //地址信息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);});}}
}

3.4 生成发票

class Program
{static void Main(string[] args){var model = InvoiceDocumentDataSource.GetInvoiceDetails();var document = new InvoiceDocument(model);// 生成PDF文件并在默认查看器中显示GenerateDocumentAndShow(document);//或者nuget安装QuestPDF Previewer预览器并尝试文档的设计//在每次代码更改后,无需重新编译即可实时执行//document.ShowInPreviewer();}static void GenerateDocumentAndShow(InvoiceDocument document){const string filePath = "invoice.pdf";document.GeneratePdf(filePath);//执行进程查看发票var process = new Process{StartInfo = new ProcessStartInfo(filePath){UseShellExecute = true}};process.Start();}
}

在这里插入图片描述

这篇关于【愚公系列】2022年10月 .NET CORE工具案例-.NET Core使用QuestPDF的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/344984

相关文章

Python按照24个实用大方向精选的上千种工具库汇总整理

《Python按照24个实用大方向精选的上千种工具库汇总整理》本文整理了Python生态中近千个库,涵盖数据处理、图像处理、网络开发、Web框架、人工智能、科学计算、GUI工具、测试框架、环境管理等多... 目录1、数据处理文本处理特殊文本处理html/XML 解析文件处理配置文件处理文档相关日志管理日期和

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

Python yield与yield from的简单使用方式

《Pythonyield与yieldfrom的简单使用方式》生成器通过yield定义,可在处理I/O时暂停执行并返回部分结果,待其他任务完成后继续,yieldfrom用于将一个生成器的值传递给另一... 目录python yield与yield from的使用代码结构总结Python yield与yield

Go语言使用select监听多个channel的示例详解

《Go语言使用select监听多个channel的示例详解》本文将聚焦Go并发中的一个强力工具,select,这篇文章将通过实际案例学习如何优雅地监听多个Channel,实现多任务处理、超时控制和非阻... 目录一、前言:为什么要使用select二、实战目标三、案例代码:监听两个任务结果和超时四、运行示例五

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do