<文本文档和pdf文件互相转化>入门练习

简介: 首先会需要两个jar包文件 itext-5.5.5和text-asian.jar,可以在我上传的资源处下载。 将这两个jar包添加到项目中。 然后编写简单的测试Demo /** * */package com.skd.util;import java.io.BufferedReader;import java.io.File;import java.io.Fil

首先会需要两个jar包文件 itext-5.5.5和text-asian.jar,可以在我上传的资源处下载。

将这两个jar包添加到项目中。

然后编写简单的测试Demo


/**
 * 
 */
package com.skd.util;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.io.Writer;

import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.util.PDFTextStripper;

import com.itextpdf.text.Document;
import com.itextpdf.text.DocumentException;
import com.itextpdf.text.Font;
import com.itextpdf.text.Paragraph;
import com.itextpdf.text.pdf.BaseFont;
import com.itextpdf.text.pdf.PdfWriter;

/**
 * @author JING
 * @date 2015年4月28日
 * @time  下午9:11:14
 * @fileName Office2PDF.java
 * @function 
 */
public class Office2PDF {
	static final String PDF_SUFFIX=".PDF";
	static final String TXT_SUFFIX=".txt";
	static final String JAVA_SUFFIX=".java";
	static final String DOCX_SUFFIX=".docx";
	static final String DOC_SUFFIX=".doc";

	/**
	 * @param args
	 * @throws Exception 
	 * @throws IOException 
	 */
	public static void main(String[] args) throws IOException, Exception {
		//这两个路径可以指定为自己的文本文件路径,不带扩展名
		String filePath="D:\\test_data\\开发";
		String pdfPath=filePath+PDF_SUFFIX;
		String txtPath=filePath+JAVA_SUFFIX;
		//文本文件转为pdf文件
		//txt2Pdf(txtPath, pdfPath);
		//获取pdf文件中的内容并保存在同名的文本文件中
		//getPdf(pdfPath);
		System.out.println("结束");
	}
	
	/**
	 * 获取pdf文件中的内容并保存在同名的文本文件中
	 * @param pdfPath
	 * @throws IOException
	 */
	public static void getPdf(String pdfPath) throws IOException {
		//是否排序
		boolean sort=false;
		//pdf文件名
		String fileName=pdfPath;
		//读取文件的内容
		String pdfContent=null;
		//编码方式
		String encoding="UTF-8";
		//开始提取页
		int startPage=1;
		//结束提取页
		int endPage=Integer.MAX_VALUE;
		//文件输入流
		Writer writer=null;
		PDDocument doc=null;
		doc=PDDocument.load(fileName);
		
		if(fileName.length() > 4){
            //以原来pdf名称来命名新产生的txt文件
            File outputFile = new File(fileName.substring(0, fileName.length()-4) + ".txt");
            fileName = outputFile.getPath();
        }
		//文件输出流,写入到filename中
		writer=new OutputStreamWriter(new FileOutputStream(fileName), encoding);
		PDFTextStripper pdfTextStripper = new PDFTextStripper();
		pdfTextStripper.setSortByPosition(sort);
		pdfTextStripper.setStartPage(startPage);
		pdfTextStripper.setEndPage(endPage);
		//调用PDFTextStripper的writeText
		pdfTextStripper.writeText(doc,writer );
		writer.close();
		 if(writer != null){
         }
		 doc.close();
         if(doc != null){
         }
	}
	
	/**
	 * 文本文件转为pdf文件
	 * @param txtPath 
	 * @param pdfPath
	 * @throws IOException
	 * @throws DocumentException
	 */
	public static void txt2Pdf(String txtPath,String pdfPath) throws IOException, DocumentException {
		Document document = new Document();
		//系统字体的路径C:\Windows\Fonts\SIMKAI.TTF 楷体常规 放置在项目src下的res下。不设置字体不显示中文
		//BaseFont bfChinese = BaseFont.createFont("res/SIMKAI.TTF",BaseFont.IDENTITY_H,   BaseFont.NOT_EMBEDDED);  //"fonts/UniGB-UCS2-H"   
		BaseFont bfChinese = BaseFont.createFont("STSongStd-Light","UniGB-UCS2-H",   BaseFont.EMBEDDED);   
	   Font FontChinese = new Font(bfChinese, 12,Font.NORMAL);  
		try {
			BufferedReader reader=new BufferedReader(new InputStreamReader(new FileInputStream(txtPath)));
			OutputStream os=new FileOutputStream(pdfPath);
			PdfWriter.getInstance(document, os);
			document.open();
			String cache=null;
			while((cache=reader.readLine())!=null){
				document.add(new Paragraph(cache, FontChinese));
			}
		} catch (DocumentException e) {
			e.printStackTrace();
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		}finally{
			document.close();
		}	
	}
}



上面代码中的两个方法就是文本文档转为pdf,然后pdf转为文本文档的过程。其他类型的转化和细节使用,

待以后继续测试使用后再来分享经验















相关文章
|
2月前
|
C#
【PDF提取内容改名】批量提取PDF指定区域内容重命名PDF文件,PDF自动提取内容命名的方案和详细步骤
本工具可批量提取PDF中的合同编号、日期、发票号等关键信息,支持PDF自定义区域提取并自动重命名文件,适用于合同管理、发票处理、文档归档和数据录入场景。基于iTextSharp库实现,提供完整代码示例与百度、腾讯网盘下载链接,助力高效处理PDF文档。
392 40
|
5月前
|
存储 JSON API
如何将 Swagger 文档导出为 PDF 文件
你会发现自己可能需要将 Swagger 文档导出为 PDF 或文件,以便于共享和存档。在这篇博文中,我们将指导你完成将 Swagger 文档导出为 PDF 格式的过程。
|
2月前
|
编译器 Python
如何利用Python批量重命名PDF文件
本文介绍了如何使用Python提取PDF内容并用于文件重命名。通过安装Python环境、PyCharm编译器及Jupyter Notebook,结合tabula库实现PDF数据读取与处理,并提供代码示例与参考文献。
|
4月前
|
人工智能 算法 安全
使用CodeBuddy实现批量转换PPT、Excel、Word为PDF文件工具
通过 CodeBuddy 实现本地批量转换工具,让复杂的文档处理需求转化为 “需求描述→代码生成→一键运行” 的极简流程,真正实现 “技术为效率服务” 的目标。感兴趣的快来体验下把
156 10
|
3月前
|
数据采集 存储 API
Python爬虫结合API接口批量获取PDF文件
Python爬虫结合API接口批量获取PDF文件
|
7月前
|
人工智能 编解码 文字识别
OCRmyPDF:16.5K Star!快速将 PDF 文件转换为可搜索、可复制的文档的命令行工具
OCRmyPDF 是一款开源命令行工具,专为将扫描的 PDF 文件转换为可搜索、可复制的文档。支持多语言、图像优化和多核处理。
859 17
OCRmyPDF:16.5K Star!快速将 PDF 文件转换为可搜索、可复制的文档的命令行工具
|
7月前
|
文字识别 Serverless 开发工具
【全自动改PDF名】批量OCR识别提取PDF自定义指定区域内容保存到 Excel 以及根据PDF文件内容的标题来批量重命名
学校和教育机构常需处理成绩单、报名表等PDF文件。通过OCR技术,可自动提取学生信息并录入Excel,便于统计分析和存档管理。本文介绍使用阿里云服务实现批量OCR识别、内容提取、重命名及导出表格的完整步骤,包括开通相关服务、编写代码、部署函数计算和设置自动化触发器等。提供Python示例代码和详细操作指南,帮助用户高效处理PDF文件。 链接: - 百度网盘:[链接](https://pan.baidu.com/s/1mWsg7mDZq2pZ8xdKzdn5Hg?pwd=8866) - 腾讯网盘:[链接](https://share.weiyun.com/a77jklXK)
799 5
|
8月前
|
机器学习/深度学习 人工智能 文字识别
Zerox:AI驱动的万能OCR工具,精准识别复杂布局并输出Markdown格式,支持PDF、DOCX、图片等多种文件格式
Zerox 是一款开源的本地化高精度OCR工具,基于GPT-4o-mini模型,支持PDF、DOCX、图片等多种格式文件,能够零样本识别复杂布局文档,输出Markdown格式结果。
685 4
Zerox:AI驱动的万能OCR工具,精准识别复杂布局并输出Markdown格式,支持PDF、DOCX、图片等多种文件格式
|
7月前
|
文字识别 BI
【图片型PDF】批量识别扫描件PDF指定区域局部位置内容,将识别内容导出Excel表格或批量改名文件,基于阿里云OCR对图片型PDF识别改名案例实现
在医疗和政务等领域,图片型PDF文件(如病历、报告、公文扫描件)的处理需求广泛。通过OCR技术识别这些文件中的文字信息,提取关键内容并保存为表格,极大提高了信息管理和利用效率。本文介绍一款工具——咕嘎批量OCR系统,帮助用户快速处理图片型PDF文件,支持区域识别、内容提取、导出表格及批量改名等功能。下载工具后,按步骤选择处理模式、进行区域采样、批量处理文件,几分钟内即可高效完成数百个文件的处理。
786 8
|
9月前
|
人工智能 文字识别 数据挖掘
MarkItDown:微软开源的多格式转Markdown工具,支持将PDF、Word、图像和音频等文件转换为Markdown格式
MarkItDown 是微软开源的多功能文档转换工具,支持将 PDF、PPT、Word、Excel、图像、音频等多种格式的文件转换为 Markdown 格式,具备 OCR 文字识别、语音转文字和元数据提取等功能。
1813 9
MarkItDown:微软开源的多格式转Markdown工具,支持将PDF、Word、图像和音频等文件转换为Markdown格式

热门文章

最新文章