表格能够直观的传达数据信息,使信息显得条理化,便于阅读同时也利于管理。那在PDF类型的文档中如何来添加表格并且对表格进行格式化操作呢?使用常规方法直接在PDF中添加表格行不通,那我们可以在借助第三方组件的情况下来实现。本篇文章中将介绍如何正确使用组件Free Spire.PDF for .NET添加表格到PDF。该组件提供了两个类PdfTable和PdfGrid用于创建表格,在进行代码编辑前,需先安装,添加Spire.PDF. dll到项目程序集中,同时添加到命名空间。下面是两种方法来添加表格的全部代码,供参考。

  一、通过PdfTable类来创建表格

  using System.Drawing;

  using Spire.Pdf;

  using Spire.Pdf.Tables;

  using Spire.Pdf.Graphics;

  using System.Data;

  namespace DrawTable1_PDF

  {

  class Program

  {

  static void Main(string[] args)

  {

  //创建一个PdfDocument类对象并向文档新添加一页

  PdfDocument doc = new PdfDocument();

  PdfPageBase page = doc.Pages.Add();

  //创建一个PdfTable对象

  PdfTable table = new PdfTable();

  //设置字体

  table.Style.DefaultStyle.Font = new PdfTrueTypeFont(new Font("Arial Unicode MS", 9f), true);

  table.Style.HeaderStyle.Font = new PdfTrueTypeFont(new Font("Arial Unicode MS", 9f), true);

  //创建一个DataTable并写入数据

  DataTable dataTable = new DataTable();

  dataTable.Columns.Add("产品类型");

  dataTable.Columns.Add("产品编号");

  dataTable.Columns.Add("采购数额(件)");

  dataTable.Columns.Add("所属月份");

  dataTable.Rows.Add(new string[] { "A", "00101", "35", "7月"});

  dataTable.Rows.Add(new string[] { "B", "00102", "56", "8月"});

  dataTable.Rows.Add(new string[] { "C", "00103", "25", "9月"});

  //填充数据到PDF表格

  table.DataSource = dataTable;

  //显示表头(默认不显示)

  table.Style.ShowHeader = true;

  //在BeginRowLayout事件处理方法中注册自定义事件

  table.BeginRowLayout += Table_BeginRowLayout;

  //将表格绘入PDF并指定位置和大小

  table.Draw(page, new RectangleF(0, 60, 200, 200));

  //保存到文档并预览

  doc.SaveToFile("PDF表格_1.pdf");

  System.Diagnostics.Process.Start("PDF表格_1.pdf");

  }

  //在自定义事件中设置行高

  private static void Table_BeginRowLayout(object sender, BeginRowLayoutEventArgs args)

  {

  args.MinimalHeight = 10f;

  }

  }

  }

  复制代码

  运行程序生成文件(可在该项目文件下bin>Debug查看)

  效果展示:

  二、通过PdfGrid类来添加表格

  using Spire.Pdf;

  using System.Drawing;

  using Spire.Pdf.Grid;

  using Spire.Pdf.Graphics;

  using Spire.Pdf.Tables;

  namespace DrawTable_PDF

  {

  class Program

  {

  static void Main(string[] args)

  {

  //创建一个PdfDocument类对象,并新添加一页到PDF文档

  PdfDocument doc = new PdfDocument();

  PdfPageBase page = doc.Pages.Add();

  //创建一个PdfGrid对象

  PdfGrid grid = new PdfGrid();

  //设置单元格边距和表格默认字体

  grid.Style.CellPadding = new PdfPaddings(1, 1, 1, 1);

  grid.Style.Font = new PdfTrueTypeFont(new Font("Arial Unicode MS", 9f), true);

  //添加一个5行6列表格到新建的PDF文档

  PdfGridRow row1 = grid.Rows.Add();

  PdfGridRow row2 = grid.Rows.Add();

  PdfGridRow row3 = grid.Rows.Add();

  PdfGridRow row4 = grid.Rows.Add();

  PdfGridRow row5 = grid.Rows.Add();

  grid.Columns.Add(6);

  //设置列宽

  foreach (PdfGridColumn col in grid.Columns)

  {

  col.Width = 55f;

  }

  //写入数据

  row1.Cells[0].Value = "新入职员工基本信息";

  row2.Cells[0].Value = "入职时间";

  row2.Cells[1].Value = "姓名";

  row2.Cells[2].Value = "部门";

  row2.Cells[3].Value = "学历";

  row2.Cells[4].Value = "联系电话";

  row2.Cells[5].Value = "正式员工";

  row3.Cells[0].Value = "3月";

  row3.Cells[1].Value = "马超";

  row3.Cells[2].Value = "研发部";

  row3.Cells[3].Value = "硕士";

  row3.Cells[4].Value = "153****6543";

  row3.Cells[5].Value = "是";

  row4.Cells[0].Value = "4月";

  row4.Cells[1].Value = "刘陵";

  row4.Cells[2].Value = "研发部";

  row4.Cells[3].Value = "本科";

  row4.Cells[4].Value = "176****5464";

  row4.Cells[5].Value = "是";

  row5.Cells[0].Value = "4月";

  row5.Cells[1].Value = "张丽";

  row5.Cells[2].Value = "研发部";

  row5.Cells[3].Value = "本科";

  row5.Cells[4].Value = "158****4103";

  row5.Cells[5].Value = "是";

  //水平和垂直方向合并单元格

  row1.Cells[0].ColumnSpan = 6;

  row4.Cells[0].RowSpan = 2;

  row3.Cells[2].RowSpan = 3;

  row4.Cells[3].RowSpan = 2;

  //设置单元格内文字对齐方式

  PdfTable table = new PdfTable();

  row1.Cells[0].StringFormat = new PdfStringFormat(PdfTextAlignment.Center);

  row4.Cells[0].StringFormat = new PdfStringFormat(PdfTextAlignment.Justify, PdfVerticalAlignment.Middle);

  row3.Cells[2].StringFormat = new PdfStringFormat(PdfTextAlignment.Justify, PdfVerticalAlignment.Middle);

  row4.Cells[3].StringFormat = new PdfStringFormat(PdfTextAlignment.Justify, PdfVerticalAlignment.Middle);

  //设置单元格背景颜色

  row1.Cells[0].Style.BackgroundBrush = PdfBrushes.LightGreen;

  //设置表格边框颜色、粗细

  PdfBorders borders = new PdfBorders();

  borders.All = new PdfPen(Color.Black, 0.1f);

  foreach (PdfGridRow pgr in grid.Rows)

  {

  foreach (PdfGridCell pgc in pgr.Cells)

  {

  pgc.Style.Borders = borders;

  }

  }

  //在指定位置绘入表格

  grid.Draw(page, new PointF(0, 40));

  //保存到文档

  doc.SaveToFile("PDF表格.pdf");

  System.Diagnostics.Process.Start("PDF表格.pdf");

  }

  }

  }

  复制代码

  (编辑:雷林鹏 来源:网络)

  

[.NET开发] C# 如何在PDF文档中创建表格的更多相关文章

  1. C# 如何在PDF文档中创建表格

    表格能够直观的传达数据信息,使信息显得条理化,便于阅读同时也利于管理.那在PDF类型的文档中如何来添加表格并且对表格进行格式化操作呢?使用常规方法直接在PDF中添加表格行不通,那我们可以在借助第三方组 ...

  2. 如何使用免费PDF控件从PDF文档中提取文本和图片

             如何使用免费PDF控件从PDF文档中提取文本和图片 概要 现在手头的项目有一个需求是从PDF文档中提取文本和图片,我以前也使用过像iTextSharp, PDFBox 这些免费的PD ...

  3. Java 在PDF文档中绘制图形

    本篇文档将介绍通过Java编程在PDF文档中绘制图形的方法.包括绘制矩形.椭圆形.不规则多边形.线条.弧线.曲线.扇形等等.针对方法中提供的思路,也可以自行变换图形设计思路,如菱形.梯形或者组合图形等 ...

  4. 如何突出显示PDF文档中的一些重要文本信息

    PDF文档中如果存在着太多的文字时,阅读者会容易遗漏很多重要的信息.但如果,文档中存在着一些特殊标记的文字时,比如标黄.标红文本时,很多人都会给予特别关注. 因此,当大家在使用pdfFactory专业 ...

  5. C# 在PDF文档中应用多种不同字体

    在PDF文档中,可绘制不同字体样式.不同语言的文字,可通过使用Standard字体.TrueType字体.CJK字体或者自定义(私有)等字体类型.下面通过C#程序代码来展示如何实现使用以上类型的字体来 ...

  6. C# 在word文档中复制表格并粘帖到下一页中

    C# 在word文档中复制表格并粘帖到下一页中 object oMissing = System.Reflection.Missing.Value;            Microsoft.Offi ...

  7. 使用Java POI来选择提取Word文档中的表格信息

    通过使用Java POI来提取Word(1992)文档中的表格信息,其中POI支持不同的ms文档类型,在具体操作中需要注意.本文主要是通过POI来提取微软2003文档中的表格信息,具体code如下(事 ...

  8. 2018-10-04 [日常]用Python读取word文档中的表格并比较

    最近想对某些word文档(docx)的表格内容作比较, 于是找了一下相关工具. 参考Automate the Boring Stuff with Python中的word部分, 试用了python-d ...

  9. [翻译] DTCoreText 从HTML文档中创建富文本

    DTCoreText 从HTML文档中创建富文本 https://github.com/Cocoanetics/DTCoreText 注意哦亲,DTRichTextEditor 这个组件是收费的,不贵 ...

随机推荐

  1. Linux基础命令---bc

    bc bc是一种算数语言,其语法和c语言类似,可以交互执行.通过命令行选项可以获得一个标准的数学库.如果请求,在处理任何文件之前定义数学库.BC从处理所有文件的代码开始.命令行中列出的文件按所列顺序排 ...

  2. POI Excel文件的读取与写入

    1. 创建目录 if(!(new File(path).isDirectory())){ new File(path).mkdirs();} 2. 读取Excel文件,并进行写入操作 Workbook ...

  3. web前端----html基础

    一.初始html 1.web服务本质 import socket sock=socket.socket(socket.AF_INET,socket.SOCK_STREAM) sock.bind((&q ...

  4. python 操作 hbase

    python 是万能的,当然也可以通过api去操作big database 的hbase了,python是通过thrift去访问操作hbase 以下是在centos7 上安装操作,前提是hbase已经 ...

  5. 高可用Mysql架构_Mysql主从复制、Mysql双主热备、Mysql双主双从、Mysql读写分离(Mycat中间件)、Mysql分库分表架构(Mycat中间件)的演变

    [Mysql主从复制]解决的问题数据分布:比如一共150台机器,分别往电信.网通.移动各放50台,这样无论在哪个网络访问都很快.其次按照地域,比如国内国外,北方南方,这样地域性访问解决了.负载均衡:M ...

  6. Confluence5.8部分空间名称显示为问号的解决方案

    Confluence5.8部分空间名称显示为问号的解决方案 原因: 连接MySQL的时候,有没有在连接串中指定&useUnicode=true&characterEncoding=ut ...

  7. 20145304 Exp4 恶意代码分析

    20145304 Exp4 恶意代码分析 实验后回答问题 (1)如果在工作中怀疑一台主机上有恶意代码,但只是猜想,所有想监控下系统一天天的到底在干些什么.请设计下你想监控的操作有哪些,用什么方法来监控 ...

  8. 20145317彭垚《网络对抗》Exp6 信息搜集与漏洞扫描

    20145317彭垚<网络对抗>Exp6 信息搜集与漏洞扫描 问题回答 1.哪些组织负责DNS,IP的管理? DNS域名服务器:绝大多数在欧洲和北美洲,中国仅拥有镜像服务器. 全球一共有5 ...

  9. 20162311 Hash 补分博客

    20162311 Hash 补分博客 一.任务详情 二.解题过程 除留余数法和拉链法都懂了,也都会做,主要是开放寻址法.课下查了一些资料,也问了老师才彻底理解 引用例子 引用网上的一个例子来理解 参考 ...

  10. JDBC中 execute 与 executeUpdate的区别

    相同点 execute与executeUpdate的相同点:都可以执行增加,删除,修改 不同点 execute可以执行查询语句 然后通过getResultSet,把结果集取出来 executeUpda ...