C#教程

关注公众号 jb51net

关闭
首页 > 软件编程 > C#教程 > C# DataTable导出PDF

C#实现将DataTable导出为PDF文档

作者:用户835629078051

本文将通过一个清晰,可落地的示例,介绍如何在 C# 中将 DataTable 导出为专业的 PDF 文档,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下

在许多业务系统中,从表格数据生成报表、发票或其他结构化文档是一项常见需求。这些数据通常存储在 C# 的 DataTable 对象中,而问题在于:.NET 本身并不提供将 DataTable 直接渲染为 PDF 的能力

本文将通过一个清晰、可落地的示例,介绍如何在 C# 中将 DataTable 导出为专业的 PDF 文档。我们将借助第三方 PDF 组件,快速实现从表格数据到 PDF 报告的自动化生成。

为什么需要以编程方式生成 PDF

在 C# 应用中,DataTable 常用于承载数据库查询结果或业务数据。虽然将其显示在界面控件(如 DataGridView)中非常容易,但当需要生成可分发、可归档、格式稳定的文档时,PDF 通常是更合适的选择。

问题在于:

因此,实际开发中通常会引入专门的 PDF 生成库,用于将表格数据映射为 PDF 表格,并自动处理分页、布局和样式。

项目准备:配置 C# PDF 导出环境

在开始导出 DataTable 之前,需要先完成项目和依赖的配置。

1. 创建 C# 项目

可以使用 控制台应用、WinForms、WPF 或 ASP.NET Core 项目,本文示例以控制台程序为例,其他类型项目原理一致。

2. 安装 PDF 组件(Spire.PDF)

通过 NuGet 安装 Spire.PDF

Install-Package Spire.PDF

或在 NuGet UI 中搜索 Spire.PDF 并安装。

3. 引入命名空间

using System;
using System.Data;
using Spire.Pdf;
using Spire.Pdf.Graphics;
using Spire.Pdf.Tables;
using System.Drawing; // 用于 Color 和 PointF

至此,项目已具备导出 PDF 的基本环境。

核心实现:将 DataTable 转换为 PDF

1. 准备示例 DataTable

下面的方法用于构造一个示例 DataTable,作为 PDF 报表的数据来源。

public static DataTable GetSampleDataTable()
{
    DataTable dataTable = new DataTable("Products");

    // 定义列
    dataTable.Columns.Add("ProductID", typeof(int));
    dataTable.Columns.Add("ProductName", typeof(string));
    dataTable.Columns.Add("Category", typeof(string));
    dataTable.Columns.Add("UnitPrice", typeof(decimal));
    dataTable.Columns.Add("UnitsInStock", typeof(int));

    // 添加示例数据行
    dataTable.Rows.Add(1, "Chai", "Beverages", 18.00m, 39);
    dataTable.Rows.Add(2, "Chang", "Beverages", 19.00m, 17);
    dataTable.Rows.Add(3, "Aniseed Syrup", "Confections", 10.00m, 13);
    dataTable.Rows.Add(4, "Chef Anton's Cajun Seasoning", "Condiments", 22.00m, 53);
    dataTable.Rows.Add(5, "Chef Anton's Gumbo Mix", "Condiments", 21.35m, 0);
    dataTable.Rows.Add(6, "Grandma's Boysenberry Spread", "Condiments", 25.00m, 120);
    dataTable.Rows.Add(7, "Uncle Bob's Organic Dried Pears", "Produce", 30.00m, 15);
    dataTable.Rows.Add(8, "Northwoods Cranberry Sauce", "Condiments", 40.00m, 6);

    return dataTable;
}

2. 基础版:将 DataTable 输出为 PDF 表格

public static void ExportDataTableToPdf(DataTable dataTable, string filePath)
{
    // 创建 PDF 文档
    PdfDocument doc = new PdfDocument();
    PdfPageBase page = doc.Pages.Add();

    // 添加标题
    string title = "Product Inventory Report";
    PdfFont titleFont = new PdfFont(PdfFontFamily.Helvetica, 20f, PdfFontStyle.Bold);
    SizeF titleSize = titleFont.MeasureString(title);
    float titleX = (page.Canvas.ClientSize.Width - titleSize.Width) / 2;
    page.Canvas.DrawString(title, titleFont, PdfBrushes.DarkBlue, titleX, 20);

    // 创建 PdfTable
    PdfTable pdfTable = new PdfTable();

    // 设置数据源
    pdfTable.DataSource = dataTable;

    // 表格样式设置
    pdfTable.Style.DefaultStyle.Font = new PdfFont(PdfFontFamily.Helvetica, 10f);
    pdfTable.Style.HeaderStyle.Font = new PdfFont(PdfFontFamily.Helvetica, 11f, PdfFontStyle.Bold);
    pdfTable.Style.HeaderStyle.BackgroundBrush = PdfBrushes.LightGray;
    pdfTable.Style.ShowHeader = true; // 显示表头

    // 绘制表格
    PdfLayoutResult result = pdfTable.Draw(page, new PointF(0, 60));

    // 保存文件
    doc.SaveToFile(filePath);
    doc.Close();
}

该方法中,PdfTable.DataSource 会自动将 DataTable 的列和行映射为 PDF 表格结构,这是整个导出的关键步骤。

3. 进阶版:带样式的 PDF 报表

public static void ExportDataTableToPdfWithStyle(DataTable dataTable, string filePath)
{
    // 创建 PDF 文档
    PdfDocument doc = new PdfDocument();
    PdfPageBase page = doc.Pages.Add();

    // 设置页边距
    doc.PageSettings.Margins.All = 40;

    // 添加标题
    string title = "Detailed Product Inventory Report";
    PdfFont titleFont = new PdfFont(PdfFontFamily.Helvetica, 24f, PdfFontStyle.Bold);
    SizeF titleSize = titleFont.MeasureString(title);
    float titleX = (page.Canvas.ClientSize.Width - titleSize.Width) / 2;
    page.Canvas.DrawString(title, titleFont, PdfBrushes.DarkBlue, titleX, 20);

    // 添加说明文字
    string introduction = "This report provides an overview of current product inventory levels, detailing product ID, name, category, unit price, and units in stock.";
    PdfFont introFont = new PdfFont(PdfFontFamily.Helvetica, 12f);
    page.Canvas.DrawString(
        introduction,
        introFont,
        PdfBrushes.Black,
        new PointF(0, 60),
        new PdfStringFormat(PdfStringFormatFlags.WordBreak) { MeasureTrailingSpaces = true }
    );

    // 计算表格起始位置
    float tableY = 60 + introFont.MeasureString(introduction, page.Canvas.ClientSize.Width).Height + 20;

    // 创建 PdfTable
    PdfTable pdfTable = new PdfTable();
    pdfTable.DataSource = dataTable;

    // 表格样式
    pdfTable.Style.DefaultStyle.Font = new PdfFont(PdfFontFamily.Helvetica, 9f);
    pdfTable.Style.HeaderStyle.Font = new PdfFont(PdfFontFamily.Helvetica, 10f, PdfFontStyle.Bold);
    pdfTable.Style.HeaderStyle.BackgroundBrush = new PdfSolidBrush(Color.FromArgb(120, 180, 230));
    pdfTable.Style.HeaderStyle.TextBrush = PdfBrushes.White;
    pdfTable.Style.ShowHeader = true;

    // 交替行背景色
    pdfTable.Style.AlternateRowStyle.BackgroundBrush = new PdfSolidBrush(Color.LightYellow);

    // 单元格内边距
    pdfTable.Style.DefaultStyle.CellPadding = 5;

    // 设置列宽
    pdfTable.Columns[0].Width = 70f;
    pdfTable.Columns[1].Width = 150f;
    pdfTable.Columns[2].Width = 100f;
    pdfTable.Columns[3].Width = 80f;
    pdfTable.Columns[4].Width = 90f;

    // 绘制表格(自动分页)
    PdfLayoutResult result = pdfTable.Draw(page, new PointF(0, tableY));

    // 保存文件
    doc.SaveToFile(filePath);
    doc.Close();
}

输出结果预览

进阶建议与最佳实践

总结

通过引入 Spire.PDF for .NET,在 C# 中将 DataTable 导出为 PDF 变得简单且高效。无论是基础表格导出,还是带样式的正式报表,该方案都能满足大多数业务系统的文档生成需求。

这种方式不仅显著减少了开发成本,也能稳定地产出专业级 PDF 文档,非常适合在企业级应用中使用。

到此这篇关于C#实现将DataTable导出为PDF文档的文章就介绍到这了,更多相关C# DataTable导出PDF内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文