using System;
using System.IO;
using System.Text;
using System.Collections;
using iTextSharp.text;
using iTextSharp.text.pdf;
using System.Windows.Forms;
namespace ExportTest
{
public class ExportPdf
{
#region 初始化,定义pdf文件页面大小
/// <summary>
/// pdf文件宽度
/// </summary>
static float pageWidth = 594.0f;
/// <summary>
/// pdf文件高度
/// </summary>
static float pageDepth = 828.0f;
/// <summary>
/// 文本与边界距离
/// </summary>
static float pageMargin = 30.0f;
/// <summary>
/// 字体大小
/// </summary>
static float fontSize = 10.0f;
/// <summary>
/// 页眉大小
/// </summary>
static float leadSize = 10.0f;
#endregion
/// <summary>
/// 在磁盘指定位置创建一个PDF文件
/// </summary>
StreamWriter pPDF;
/// <summary>
/// 在内存中创建文件缓冲区
/// </summary>
MemoryStream mPDF;
public ExportPdf(string fileName)
{
//pPDF = new StreamWriter(fileName);
//mPDF = new MemoryStream();
}
/// <summary>
/// 将文本文件数据转换成pdf格式并写入文件缓冲区的函数
/// </summary>
/// <param name="strMsg">文本</param>
private void ConvertToByteAndAddtoStream(string strMsg)
{
Byte[] buffer = null;
buffer = ASCIIEncoding.ASCII.GetBytes(strMsg);
mPDF.Write(buffer, 0, buffer.Length);
buffer = null;
}
/// <summary>
/// 将数据长度格式信息格式化为外部参照格式
/// </summary>
/// <param name="xValue"></param>
/// <returns></returns>
private string xRefFormatting(long xValue)
{
string strMsg = xValue.ToString();
int iLen = strMsg.Length;
if (iLen < 10)
{
StringBuilder s = new StringBuilder(); //StringBuilder是修改字符串的类
int i = 10 - iLen;
s.Append('0', i);
strMsg = s.ToString() + strMsg;
}
return strMsg;
}
/// <summary>
/// 导出pdf文件
/// </summary>
public void ExportToPdf()
{
//为pdf文件的外部格式创建一个队列列表
ArrayList xRefs = new ArrayList();
float yPos = 0f;
long streamStart = 0;
long streamEnd = 0;
long streamLen = 0;
string strPDFMessage = null; //PDF文件的头信息
strPDFMessage = "%PDF-1.1\n";
ConvertToByteAndAddtoStream(strPDFMessage); //将头信息转换成字节并加入文件缓冲区
//开始新的一页
xRefs.Add(mPDF.Length);
strPDFMessage = "1 0 obj\n"; //ID 1 For Containt
ConvertToByteAndAddtoStream(strPDFMessage); //write the Text
strPDFMessage = "<< /Length 2 0 R >>\n"; //ID 2 For Length of the Stream
ConvertToByteAndAddtoStream(strPDFMessage);
strPDFMessage = "stream\n";
ConvertToByteAndAddtoStream(strPDFMessage);
//得到缓冲区的开始
streamStart = mPDF.Length;
strPDFMessage = "BT\n/F0 " + fontSize + " Tf\n";
ConvertToByteAndAddtoStream(strPDFMessage);
yPos = pageDepth - pageMargin;
strPDFMessage = pageMargin + " " + yPos + " Td\n";
ConvertToByteAndAddtoStream(strPDFMessage);
strPDFMessage = leadSize + " TL\n";
ConvertToByteAndAddtoStream(strPDFMessage);
for (int i = 0; i < 300; i++)
{
//输入文本信息到文件缓冲区
strPDFMessage = "(It is a new test!)Tj\n";//
ConvertToByteAndAddtoStream(strPDFMessage);
strPDFMessage = "\n";
ConvertToByteAndAddtoStream(strPDFMessage);
}
strPDFMessage = "ET\n";
ConvertToByteAndAddtoStream(strPDFMessage);
//得到缓冲区的结尾
streamEnd = mPDF.Length;
//得到缓冲区的长度
streamLen = streamEnd - streamStart;
strPDFMessage = "endstream\nendobj\n";
ConvertToByteAndAddtoStream(strPDFMessage);
//将第二个目标加入外部参照格式
xRefs.Add(mPDF.Length);
strPDFMessage = "2 0 obj\n" + streamLen + "\nendobj\n";
ConvertToByteAndAddtoStream(strPDFMessage);
ConvertToByteAndAddtoStream(strPDFMessage);
//将页信息加入到外部参照模式
xRefs.Add(mPDF.Length);
strPDFMessage = "3 0 obj\n<</Type/Page/Parent 4 0 R/Contents 1 0 R>>\nendobj\n";
ConvertToByteAndAddtoStream(strPDFMessage);
//建立这个页
xRefs.Add(mPDF.Length);
strPDFMessage = "4 0 obj\n<</Type /Pages /Count 1\n";
ConvertToByteAndAddtoStream(strPDFMessage);
strPDFMessage = "/Kids[\n3 0 R\n]\n";
ConvertToByteAndAddtoStream(strPDFMessage);
strPDFMessage = "/Resources<</ProcSet[/PDF/Text]/Font<</F0 5 0 R>> >>\n";
ConvertToByteAndAddtoStream(strPDFMessage);
strPDFMessage = "/MediaBox [ 0 0 " + pageWidth + " " + pageDepth + "]\n>>\nendobj\n";
ConvertToByteAndAddtoStream(strPDFMessage);
//将字体信息加入到外部参照模式
xRefs.Add(mPDF.Length);
strPDFMessage = "5 0 obj\n<</Type/Font/Subtype/Type1/BaseFont/Courier/Encoding/WinAnsiEncoding>>\nendobj\n";
ConvertToByteAndAddtoStream(strPDFMessage);
//将目录信息加入到外部参照模式
xRefs.Add(mPDF.Length);
strPDFMessage = "6 0 obj\n<</Type/Catalog/Pages 4 0 R>>\nendobj\n";
ConvertToByteAndAddtoStream(strPDFMessage);
//外部参照模式入口
streamStart = mPDF.Length;
strPDFMessage = "xref\n0 7\n0000000000 65535 f \n";
for (int i = 0; i < xRefs.Count; i++)
{
strPDFMessage += xRefFormatting((long)xRefs[i]) + " 00000 n \n";
}
ConvertToByteAndAddtoStream(strPDFMessage);
//PDF位置信息
strPDFMessage = "trailer\n<<\n/Size " + (xRefs.Count + 1) + "\n/Root 6 0 R\n>>\n";
ConvertToByteAndAddtoStream(strPDFMessage);
//外部参照模式本地入口
strPDFMessage = "startxref\n" + streamStart + "\n%%EOF\n";
ConvertToByteAndAddtoStream(strPDFMessage);
//将文件缓冲区的内容写入到文件
mPDF.WriteTo(pPDF.BaseStream);
//关闭缓冲区
mPDF.Close();
pPDF.Close();
}
/// <summary>
/// 使用itextSharp导出pdf
/// </summary>
/// <param name="fileName">导出到的pdf文件名</param>
/// <param name="picName">导出到pdf的图片名</param>
public static void ExportToPdf(string fileName, string picName)
{
Document document = new Document();
FileStream fs = System.IO.File.Open(fileName, FileMode.OpenOrCreate);
PdfWriter.GetInstance(document, fs);
document.Open();
BaseFont bfChinese = BaseFont.CreateFont(@"C:\WINDOWS\Fonts\SIMFANG.TTF", BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED);
Font fontChinese = new Font(bfChinese, 12);
Image img = Image.GetInstance(picName);
document.Add(img);
Table aTable = new Table(1, 3);
aTable.Border = 0;
Cell cell = new Cell();
aTable.AddCell(new Paragraph(" 卡极度疯狂江户时代开发计划 \n ", fontChinese));
aTable.AddCell(new Paragraph("阿克苏叫的话发看见是大方好\n ", fontChinese));
document.Add(aTable);
aTable = new Table(2, 3);
cell = new Cell(new Paragraph("\n\n基础能力评估", fontChinese));
cell.Rowspan = 3;
cell.Border = 0;
aTable.AddCell(cell);
aTable.AddCell(new Paragraph("评分:" + "4.5 分\n ", fontChinese));
cell = new Cell(new Paragraph("描述:龙卡及是肯定发贺卡吉林省地方看见了哈深刻理解对方哈可是敦伦尽分贺卡老实交代回复刻录机啊是大方科技哈萨克断金零粉哈卡睡懒觉等会风口浪尖阿斯顿后付款\n ", fontChinese));
cell.Rowspan = 2;
aTable.AddCell(cell);
document.Add(aTable);
aTable = new Table(2, 3);
cell = new Cell(new Paragraph("\n\n阿里看见是大家发看见好", fontChinese));
cell.Rowspan = 3;
cell.Border = 0;
aTable.AddCell(cell);
aTable.AddCell(new Paragraph("评分:" + "3 分\n ", fontChinese));
cell = new Cell(new Paragraph("描述:龙卡及是肯定发贺卡吉林省地方看见了哈深刻理解对方哈可是敦伦尽分贺卡老实交代回复刻录机啊是大方科技哈萨克断金零粉哈卡睡懒觉等会风口浪尖阿斯顿后付款\n ", fontChinese));
cell.Rowspan = 2;
aTable.AddCell(cell);
document.Add(aTable);
aTable = new Table(2, 3);
cell = new Cell(new Paragraph("\n\n龙卡及地方看见", fontChinese));
cell.Rowspan = 3;
cell.Border = 0;
aTable.AddCell(cell);
aTable.AddCell(new Paragraph("评分:" + "4 分\n ", fontChinese));
cell = new Cell(new Paragraph("描述:龙卡及是肯定发贺卡吉林省地方看见了哈深刻理解对方哈可是敦伦尽分贺卡老实交代回复刻录机啊是大方科技哈萨克断金零粉哈卡睡懒觉等会风口浪尖阿斯顿后付款 \n ", fontChinese));
cell.Rowspan = 2;
aTable.AddCell(cell);
document.Add(aTable);
aTable = new Table(2, 3);
cell = new Cell(new Paragraph("\n\n可连接的说法:", fontChinese));
cell.Rowspan = 3;
cell.Border = 0;
aTable.AddCell(cell);
aTable.AddCell(new Paragraph("评分:" + "3.5 分\n ", fontChinese));
cell = new Cell(new Paragraph("描述:会风口浪尖阿可垃圾的附件哈开始就大方好可怜见哈师大开发计划撒打开了附件斯顿后付款 \n", fontChinese));
cell.Rowspan = 2;
aTable.AddCell(cell);
document.Add(aTable);
aTable = new Table(2, 1);
aTable.AddCell(new Paragraph("评审人:Prewin \n ", fontChinese));
aTable.AddCell(new Paragraph("评审时间:2008-10-23 \n ", fontChinese));
cell.Border = 0;
document.Add(aTable);
//备注
aTable = new Table(1, 1);
cell = new Cell(new Paragraph(" 备注 \n 会风口浪尖阿可垃圾的附件哈开始就大方好可kljhskjalhf ksajldfh看了就大方了哈师大看见阿拉沙德卡机是怜见哈师大开发计划撒打开了附件斯顿后付款 \n ", fontChinese));
aTable.AddCell(cell);
document.Add(aTable);
document.Close();
}
}
}
分享到:
相关推荐
PDF文件是目前比较流行的电子文档格式,在办公自动化(OA)等软件的开发中,经常要用到该格式,但介绍如 何制作PDF格式文件的资料非常少,在网上搜来搜去,都转贴的是同一段“暴力”破解的方法
本案例聚焦于C#导出PDF的功能,这是一个常见的需求,例如在报表生成、文档自动化或者数据导出场景中。PDF作为一种便携式文档格式,能够跨平台保持一致的显示效果,因此在许多业务流程中被广泛采用。 要实现在C#中...
接下来,我们讨论C#导出PDF。PDF是一种跨平台的文件格式,适合用于生成报告和文档。有多种库可以用于C#中的PDF生成,如iTextSharp、PDFSharp和Syncfusion Essential PDF等。以iTextSharp为例,这是一个流行的PDF处理...
要在C#中导出PDF,我们需要使用一个库来处理PDF的创建和操作。其中一个常见的库是iTextSharp,这是一个开源的.NET库,能够方便地创建、修改和读取PDF文档。首先,你需要从NuGet包管理器安装iTextSharp库到你的项目中...
### C#导出PDF格式:使用iTextSharp的详尽指南 #### 引言 PDF(Portable Document Format)是一种广泛使用的文件格式,尤其在办公自动化(OA)领域中,其重要性不言而喻。然而,如何在C#中生成PDF文件却是一个常见...
在"导出PDF"这个场景中,我们通常会涉及到以下知识点: 1. **PDF文档结构**:PDF文档由多个对象组成,包括页面、字体、图像、注释等。iTextSharp允许你直接操作这些对象来构建文档。 2. **创建PDF文档**:首先,你...
接下来,我们讨论C#导出PDF。PDF(Portable Document Format)是一种通用的文件格式,用于保持文档的原始布局和样式。在C#中,有多个库可以生成PDF,例如iTextSharp、PDFSharp和Syncfusion Essential PDF等。这些库...
本话题主要探讨如何利用C#将网页内容导出为PDF文件,这在报告生成、电子文档制作等方面非常实用。这里我们将详细讲解这个过程,以及涉及到的关键技术——wkhtmltopdf。 wkhtmltopdf是一个开源命令行工具,它可以将...
总结一下,这个C# WinForm的ItextSharp PDF导出示例主要涉及以下步骤: 1. 引入ItextSharp库。 2. 创建WinForm界面,绑定导出按钮的Click事件。 3. 在事件处理程序中调用`ExportToPdf`方法,传递待导出的文本和目标...
标题中的"C# .NET Core MVC导出PDF"指的是在C#编程环境中,使用.NET Core框架的MVC(Model-View-Controller)模式来创建Web应用,并实现从该应用导出数据到PDF文档的功能。.NET Core是Microsoft开发的一个开源、跨...
本主题将深入探讨如何利用C#的NPOI库导出Excel文件以及如何借助Aspose.Words库将Word文档转换为PDF,同时保持无水印的高质量输出。 首先,让我们关注C# NPOI导出Excel的部分。NPOI提供了API,使得开发者可以轻松地...
### C# 生成PDF源码:图片导入与文本布局详解 #### 一、概述 在C#编程语言中,利用第三方库(如iTextSharp)可以实现生成PDF文档的功能。本篇文章将详细介绍如何通过C#代码来创建一个带有图片及中文、英文文本布局...
在C#的Windows Presentation Foundation(WPF)框架中,PDF的导出与读取是常见的需求,尤其是在开发桌面应用程序时。本教程将详细介绍如何利用iTextSharp库来完成这一任务。iTextSharp是一个流行的.NET库,它允许...
当涉及到生成PDF文件时,C#提供了多种方法来实现这一功能。PDF(Portable Document Format)文件格式因其跨平台性和易于共享的特性,常用于文档的创建和分发。本篇文章将深入探讨如何利用C#生成PDF文件。 首先,...
首先,对于C#导出Excel,最常用的库是Microsoft.Office.Interop.Excel,它是.NET框架的一部分,允许开发者直接操作Excel对象模型来创建、编辑和保存Excel文件。但是,这个库需要在用户的机器上安装Office,这可能...
本文将深入探讨如何利用C#语言在Winform环境中将DataTable数据转换并导出为PDF文件。PDF(Portable Document Format)是一种广泛接受的文档格式,能够保持原始文档的布局和格式,方便跨平台查看。 首先,我们需要...
在这个场景下,我们将深入探讨如何使用C#和Itextsharp库根据模板导出PDF报表。 首先,我们需要理解模板的概念。模板通常是一个预定义的PDF文件,包含固定的布局和样式,而实际的数据将被插入到这些预定的位置。在...