




免费预览已结束,剩余40页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
用C#制作PDF文件全攻略前 言PDF文件是目前比较流行的电子文档格式,在办公自动化(OA)等软件的开发中,经常要用到该格式,但介绍如何制作PDF格式文件的资料非常少.本文主要说下itext生成pdf复杂表格。并附上网上一个最全面的itext教程.效果如下图:目 录前 言1第一部分 iText pdf表格生成教程3第一步:引用itextsharp.dll4第二步:创建pdf文档的实例4第三步:定义字体,并打印标题.(处理中文字休)4第三步:输入一个空行(换行)。以分开标题与表格5第四步:定义基础表格cell,设置边距,解决表格内容垂直居中的问题(因为直接设置垂直居中是没有效的水平居中有效)5第5步:定义基本表格。定义图片cell。(生成表格时,从上而下生成。图片不能最后插入)5第6步:多行多列的表格5第7步:插入图片6第7步:插入一个空行(内容为空的表格)6完整代码7第一部分 iText pdf表格生成教程第一步:引用itextsharp.dllusing iTextSharp.text;using System.IO;using iTextSharp.text.pdf;第二步:创建pdf文档的实例/创建一个iTextSharp.text.Document 对象的实例: Document document = new Document(); /为该Document 创建一个Writer 实例: PdfWriter.GetInstance(document, new FileStream(C:UsershechaoDesktop报名表格.pdf, FileMode.Create); /打开当前Document document.Open();第三步:定义字体,并打印标题.(处理中文字休) / SIMSUN.TTC:宋体和新宋体/SIMKAI.TTF:楷体/SIMHEI.TTF:黑体/SIMFANG.TTF:仿宋体 BaseFont bftitle = BaseFont.CreateFont(C:WindowsFontsSIMHEI.TTF,BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED); Font fonttitle = new Font(bftitle, 20);BaseFont bf1 = BaseFont.CreateFont(C:WindowsFontsSIMSUN.TTC,1, BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED);Font font1 = new Font(bf1, 12);Font fonttitle10 = new Font(bf1, 12); Paragraph Title = new Paragraph(XXXX比赛, fonttitle);Title.SetAlignment(center);document.Add(Title);第三步:输入一个空行(换行)。以分开标题与表格Paragraph nullp = new Paragraph( , fonttitle);nullp.Leading = 10; document.Add(nullp);第四步:定义基础表格cell,设置边距,解决表格内容垂直居中的问题(因为直接设置垂直居中是没有效的水平居中有效)iTextSharp.text.pdf.PdfPCell cellmode = new iTextSharp.text.pdf.PdfPCell();cellmode.Padding = 4F; (cellmode.PaddingBottom = 6F;/这里可以分别设置)第5步:定义基本表格。定义图片cell。(生成表格时,从上而下生成。图片不能最后插入)iTextSharp.text.pdf.PdfPCell cell_pic10 = new iTextSharp.text.pdf.PdfPCell(); / 创建单元格 iTextSharp.text.pdf.PdfPCell cell_pic20 = new iTextSharp.text.pdf.PdfPCell(); / 创建单元格 iTextSharp.text.pdf.PdfPTable table = new iTextSharp.text.pdf.PdfPTable(8); / 表格有7列 table.SetWidths(new float 90,90,90,90,120,90,90,130 );/宽第6步:多行多列的表格cell = new iTextSharp.text.pdf.PdfPCell(); cell.Colspan = 1; cell.Rowspan = 4;第7步:插入图片cell = new iTextSharp.text.pdf.PdfPCell(); cell.Colspan = 1; cell.Rowspan = 4; System.Drawing.Image img_1 = System.Drawing.Image.FromFile(C:UsershechaoDesktop1.jpg); iTextSharp.text.Image img0 = iTextSharp.text.Image.GetInstance(img_1, iTextSharp.text.BaseColor.WHITE); if (img_1.Width cell.Width | img_1.Height cell.Height) img0.ScaleToFit(cell.Width, cell.Height); cell.FixedHeight = cell.MinimumHeight; cell.Image = img0; table.AddCell(cell); img_1.Dispose();第7步:插入一个空行(内容为空的表格)cell = new iTextSharp.text.pdf.PdfPCell(); cell.MinimumHeight = 60; cell.Colspan = 2; table.AddCell(cell);最终效果如下图:完整代码using System;using System.Collections.Generic;using System.Web;using iTextSharp.text;using iTextSharp.text.pdf;using System.IO;using System.Xml;using System.Data;namespace JetsenNet.JCAS.DataAccess public class createpdf public void create(XmlDocument xmlDoc, string reqpath, JetsenNet.JCAS.DataAccess.dbaccess db, string filepath, string filename) string raceId = xmlDoc.DocumentElement.SelectSingleNode(Record/OWNER_ID).InnerText; DataSet raceData = db.getRaceData(raceId); XmlDocument raceDoc = new XmlDocument(); raceDoc.LoadXml(raceData.GetXml(); /第一步,创建一个iTextSharp.text.Document 对象的实例: Document document = new Document(); /第二步,为该Document 创建一个Writer 实例: /Stream reos=new Stream(); / FileStream fs = new FileStream(C:UsershechaoDesktopChap0101.pdf, FileMode.Create); /PdfWriter.GetInstance(document, reos); PdfWriter.GetInstance(document, new FileStream(filepath + filename, FileMode.Create); /第三步,打开当前Document document.Open(); /第四步,为当前Document 添加内容: / SIMSUN.TTC:宋体和新宋体 /SIMKAI.TTF:楷体 /SIMHEI.TTF:黑体 /SIMFANG.TTF:仿宋体 BaseFont bftitle = BaseFont.CreateFont(filepath + SIMHEI.TTF, BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED); Font fonttitle = new Font(bftitle, 20); BaseFont bf1 = BaseFont.CreateFont(filepath + SIMSUN.TTC,1, BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED); Font font1 = new Font(bf1, 12); Font fonttitle10 = new Font(bf1, 10); iTextSharp.text.pdf.PdfPCell cellmode = new iTextSharp.text.pdf.PdfPCell(); cellmode.PaddingBottom = 6F; string raceLevel = db.numberToString(int.Parse(raceDoc.DocumentElement.SelectSingleNode(Record/NUM_VAL1).InnerText); string title = 第 + raceLevel + 届 + raceDoc.DocumentElement.SelectSingleNode(Record/OBJ_NAME).InnerText; Paragraph Title = new Paragraph(title, fonttitle); Title.Alignment = 1; document.Add(Title); Paragraph nullp = new Paragraph( , fonttitle); nullp.Leading = 10; document.Add(nullp); iTextSharp.text.pdf.PdfPCell cell_pic10 = new iTextSharp.text.pdf.PdfPCell(); / 创建单元格 iTextSharp.text.pdf.PdfPCell cell_pic20 = new iTextSharp.text.pdf.PdfPCell(); / 创建单元格 iTextSharp.text.pdf.PdfPTable table = new iTextSharp.text.pdf.PdfPTable(8); / 表格有7列 table.SetWidths(new float 90,90,90,90,120,90,90,130 );/宽 string picpaht_10 = ;/编导图片 string picpaht_20 = ;/演员图片 int row_usercount = 4;/人员总数 int row_usercount1 = 0;/编导人员总数 int row_usercount2 = 0;/演员人员总数 int row_usercount3 = 0;/音乐人员总数 int row_usercount4 = 0;/服装人员总数 bool needto = true; DataTable dt10 = db.getuserpd(10); DataTable dt20 = db.getuserpd(20); DataTable dt30 = db.getuserpd(30); DataTable dt40 = db.getuserpd(40); if (dt10 != null & dt10.Rows.Count 0) row_usercount1 = dt10.Rows.Count; if (dt10.Rows06 != null & dt10.Rows07 != null) picpaht_10 = dt10.Rows06.ToString() + dt10.Rows07.ToString(); if (dt20 != null & dt20.Rows.Count 0) row_usercount2 = dt20.Rows.Count; if (dt20.Rows06 != null & dt20.Rows07 != null) picpaht_20 = dt20.Rows06.ToString() + dt20.Rows07.ToString(); if (dt30 != null & dt30.Rows.Count 0) row_usercount3 = dt30.Rows.Count; if (dt40 != null & dt40.Rows.Count 0) row_usercount4 = dt40.Rows.Count; row_usercount = (row_usercount1 = 0 ? 1 : row_usercount1) + (row_usercount2 = 0 ? 1 : row_usercount2) + (row_usercount3 = 0 ? 1 : row_usercount3) + (row_usercount4 = 0 ? 1 : row_usercount4); #region 第一行 iTextSharp.text.pdf.PdfPCell cell = new iTextSharp.text.pdf.PdfPCell(cellmode); / 创建单元格 cell.Colspan = 1; Paragraph table_t = new Paragraph(作品名称, fonttitle10); table_t.Alignment = 0; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 2; table_t = new Paragraph(xmlDoc.DocumentElement.SelectSingleNode(Record/OBJ_NAME).InnerText, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(作品长度, fonttitle10); table_t.Alignment = 0; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(xmlDoc.DocumentElement.SelectSingleNode(Record/FIELD_9).InnerText, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(创作时间, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(xmlDoc.DocumentElement.SelectSingleNode(Record/FIELD_11).InnerText, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell_pic10 = new iTextSharp.text.pdf.PdfPCell(cellmode); cell_pic10.Colspan = 1; cell_pic10.Rowspan = 4; if (picpaht_10.Length 0) System.Drawing.Image img_1 = System.Drawing.Image.FromFile(reqpath + picpaht_10); iTextSharp.text.Image img0 = iTextSharp.text.Image.GetInstance(img_1, iTextSharp.text.BaseColor.WHITE); if (img_1.Width cell.Width | img_1.Height cell.Height) img0.ScaleToFit(cell.Width, cell.Height); cell_pic10.FixedHeight = cell.MinimumHeight; cell_pic10.Image = img0; img_1.Dispose(); table.AddCell(cell_pic10); #endregion #region 第二行 cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(参赛类别, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 2; table_t = new Paragraph(xmlDoc.DocumentElement.SelectSingleNode(Record/CTRLNAME).InnerText, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(参赛组别, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 3; table_t = new Paragraph(xmlDoc.DocumentElement.SelectSingleNode(Record/CW_NAME).InnerText, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); #endregion #region 第三行 cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(领队姓名, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 4; table_t = new Paragraph(xmlDoc.DocumentElement.SelectSingleNode(Record/FIELD_3).InnerText, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 2; cell.Rowspan = 2; table_t = new Paragraph(领队签名, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); #endregion #region 第4行 cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(联系方式, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 4; table_t = new Paragraph(xmlDoc.DocumentElement.SelectSingleNode(Record/FIELD_4).InnerText, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); #endregion #region 第5行 主创人员姓名单位学历出生年月联系电话备注 cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(主创人员, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(姓名, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(单位, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(学历, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(出生年月, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(联系电话, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(备注, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(照片, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); #endregion /人员开始 string date_user = ; if (row_usercount 4)/没有内容也默认空行,所以最少为4 row_usercount = 4; #region 编导 needto = true; for (int i = 0; i row_usercount1 | needto = true; i+) if (i = 0) cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Rowspan = row_usercount1 = 0 ? 1 : row_usercount1; table_t = new Paragraph(编导, fonttitle10); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); if (row_usercount1 = 0)/没有数据 for (int j = 0; j 6; j+) cell = new iTextSharp.text.pdf.PdfPCell(cellmode); cell.Colspan = 1; table_t = new Paragraph(); table_t.Alignment = 1; cell.AddElement(table_t); table.AddCell(cell); else for (int j = 0; j 17) date_user = date_user.Substring(6, 8); date_user = date_user.Substring(0, 4) + / + date_user.Substring(4, 2) +
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年中学教师资格考试《综合素质》教育案例真题模拟实战试卷(含答案)
- 2025年中学教师资格考试《综合素质》教师职业道德知识问答试卷(含答案)
- 2025年辅导员招聘考试:心理健康教育案例分析与试题库
- 建筑工地施工安全测试题及答案解析
- 贝苗多环境适应性育种及其分子标记研究-洞察及研究
- 微服务插件集成策略-洞察及研究
- 2025年合同房屋租赁协议怎么写5篇
- 住宅新能源政策分析-洞察及研究
- 购物中心运营风险控制-洞察及研究
- 网络安全意识培训试题及答案解析
- (2025年)政工师考试试题(附答案)
- 2025版简易劳务合同模板
- 2025年浙江省单独考试招生语文试卷试题真题(含答案详解)
- 消防水池挖槽施工方案
- 常微分方程教案
- 高三试卷:2025届浙江省“江浙皖县中”共同体高三10月联考-政治试题+答案
- 手术室实习生带教课件
- 拌合站拆除作业安全技术交底
- 胰岛素的种类及应用(共26张PPT)
- GB/T 96.1-2002大垫圈A级
- 2022年湖南食品药品职业学院单招综合素质考试笔试试题及答案解析
评论
0/150
提交评论