java导出PDF文档

Python014

java导出PDF文档,第1张

java导出pdf需要用到iText库,iText是著名的开放源码的站点sourceforge一个项目,是用于生成PDF文档的一个java类库。通过iText不仅可以生成PDF或rtf

的文档,而且可以将XML、Html文件转化为PDF文件。

iText的安装非常方便,下载iText.jar文件后,只需要在系统的CLASSPATH中加入iText.jar的路径,在程序中就可以使用

iText类库了。

代码如下:

public class createPdf {

//自己做的一个简单例子,中间有图片之类的

//先建立Document对象:相对应的 这个版本的jar引入的是com.lowagie.text.Document

Document document = new Document(PageSize.A4, 36.0F, 36.0F, 36.0F, 36.0F)

public void getPDFdemo() throws DocumentException, IOException{

//这个导出用的是 iTextAsian.jar 和iText-2.1.3.jar 属于比较老的方法。 具体下在地址见:

//首先

//字体的定义:这里用的是自带的jar里面的字体

BaseFont bfChinese = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", false)

// 当然你也可以用你电脑里面带的字体库

//BaseFont bfChinese = BaseFont.createFont("C:/WINDOWS/Fonts/SIMSUN.TTC,1",BaseFont.IDENTITY_H, BaseFont.EMBEDDED)

//定义字体 注意在最新的包里面 颜色是封装的

Font fontChinese8 = new Font(bfChinese, 10.0F, 0, new Color(59, 54, 54))

//生成pdf的第一个步骤:

//保存本地指定路径

saveLocal()

document.open()

ByteArrayOutputStream ba = new ByteArrayOutputStream()

// PdfWriter writer = PdfWriter.getInstance(document, ba)

document.open()

//获取此编译的文件路径

String path = this.getClass().getClassLoader().getResource("").getPath()

//获取根路径

String filePath = path.substring(1, path.length()-15)

//获取图片路径 找到你需要往pdf上生成的图片

//这里根据自己的获取的路径写 只要找到图片位置就可以

String picPath = filePath +"\\WebContent" +"\\images\\"

//往PDF中添加段落

Paragraph pHeader = new Paragraph()

pHeader.add(new Paragraph(" 你要生成文字写这里", new Font(bfChinese, 8.0F, 1)))

//pHeader.add(new Paragraph("文字", 字体 可以自己写 也可以用fontChinese8 之前定义好的 )

document.add(pHeader)//在文档中加入你写的内容

//获取图片

Image img2 = Image.getInstance(picPath +"ccf-stamp-new.png")

//定义图片在文档中显示的绝对位置

img2.scaleAbsolute(137.0F, 140.0F)

img2.setAbsolutePosition(330.0F, 37.0F)

//将图片添加到文档中

document.add(img2)

//关闭文档

document.close()

/*//设置文档保存的文件名

response.setHeader("Content-

disposition", "attachmentfilename=\""+ new String(("CCF会员资格确认

函.pdf").getBytes("GBK"),"ISO-8859-1") + "\"")

//设置类型

response.setContentType("application/pdf")

response.setContentLength(ba.size())

ServletOutputStream out = response.getOutputStream()

ba.writeTo(out)

out.flush()*/

}

public static void main(String[]args) throws DocumentException, IOException{

createPdf pdf= new createPdf()

pdf.getPDFdemo()

}

//指定一个文件进行保存 这里吧文件保存到D盘的text.pdf

public void saveLocal() throws IOException, DocumentException{

//直接生成PDF 制定生成到D盘test.pdf

File file = new File("D:\\text2.pdf")

file.createNewFile()

PdfWriter.getInstance(document, new FileOutputStream(file))

}

}

可以使用Spire.XLS for Java实现把Excel转为PDF文档。

首先,您需要在 Java 程序中添加 Spire.Xls.jar 文件作为依赖项。您可以从这个链接下载 JAR 文件;如果您使用 Maven,则可以通过在 pom.xml 文件中添加以下代码导入 JAR 文件。

<repositories>

<repository>

<id>com.e-iceblue</id>

<url>https://repo.e-iceblue.cn/repository/maven-public/</url>

</repository></repositories><dependencies>

<dependency>

<groupId>e-iceblue</groupId>

<artifactId>spire.xls</artifactId>

<version>5.3.3</version>

</dependency></dependencies>

将整个 Excel 文件转换为 PDF

以下是将整个 Excel 文档转换为 PDF 的步骤。

创建一个 Workbook 对象。

使用 Workbook.loadFromFile() 方法加载示例 Excel 文档。

通过 Workbook.getConverterSetting() 方法返回的 ConverterSetting 对象下的方法设置 Excel 到 PDF 的转换选项。

使用 Workbook.saveToFile() 方法将整个 Excel 文档转换为 PDF。

代码如下:

import com.spire.xls.FileFormatimport com.spire.xls.Workbookpublic class ConvertExcelToPdf {

public static void main(String[] args) {

//创建一个Workbook实例并加载Excel文件

Workbook workbook = new Workbook()

workbook.loadFromFile("C:\\Users\\Administrator\\Desktop\\Sample.xlsx")

//设置转换后的PDF页面高宽适应工作表的内容大小

workbook.getConverterSetting().setSheetFitToPage(true)

//将生成的文档保存到指定路径

workbook.saveToFile("output/ExcelToPdf", FileFormat.PDF)

}

}