网站首页 > java教程 正文
在前文中我曾介绍过如何利用Java代码在PDF文档中创建表格。那对于一个已经包含有表格的PDF文档,想要提取其中表格信息进行编辑分析是否可行呢?答案是可以。用到的工具同样是Spire.PDF for Java控件,需用到它的最新版4.10.2。
以下是PDF示例文档:
导入Jar包:在E-iceblue中文官网下载Spire.PDF for Java产品包,解压后在lib文件夹下找到Spire.Pdf.jar,然后将其手动导入IDEA;如果用Maven仓库安装方式,在pom.xml里键入以下代码即可。
<repositories>
<repository>
<id>com.e-iceblue</id>
<name>e-iceblue</name>
<url>https://repo.e-iceblue.com/nexus/content/groups/public/</url>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId> e-iceblue </groupId>
<artifactId>spire.pdf</artifactId>
<version>4.10.2</version>
</dependency>
</dependencies>
代码示例
Spire.PDF for Java提供了PdfTableExtractor.extractTable(int pageIndex)方法来检测和提取PDF文档中的表格信息。以下是具体实现步骤:
- 创建PdfDocument实例
- 使用PdfDocument.loadFromFile()方法加载PDF示例文档
- 创建StringBuilder和PdfTableExtractor实例
- 遍历文档所有页面,然后使用PdfTableExtractor.extractTable(int pageIndex)方法提取表格到PdfTable 数组
- 遍历表格的所有行和列,然后使用PdfTable.getText(int rowIndex, int columnIndex)方法提取数据,最终通过StringBuilder.append()方法将数据保存到StringBuilder实例
- 使用Writer.write()方法将提取的表格数据写入.txt文档
import com.spire.pdf.PdfDocument;
import com.spire.pdf.utilities.PdfTable;
import com.spire.pdf.utilities.PdfTableExtractor;
import java.io.FileWriter;
import java.io.IOException;
public class ExtractTable {
public static void main(String[] args) throws IOException {
//创建PdfDocument实例
PdfDocument pdf = new PdfDocument();
//加载PDF示例文档
pdf.loadFromFile("C:\\Users\\Test1\\Desktop\\sample.pdf");
//创建StringBuilder和PdfTableExtractor实例
StringBuilder builder = new StringBuilder();
PdfTableExtractor extractor = new PdfTableExtractor(pdf);
//遍历PDF文档的所有页
for (int pageIndex = 0; pageIndex < pdf.getPages().getCount(); pageIndex++) {
PdfTable[] tableLists = extractor.extractTable(pageIndex);
if (tableLists != null && tableLists.length > 0) {
for (PdfTable table : tableLists) {
//获取表格的所有行
for (int i = 0; i < table.getRowCount(); i++) {
//获取表格所有列
for (int j = 0; j < table.getColumnCount(); j++) {
//提取表格中的所有数据至StringBuilder
String text = table.getText(i, j);
builder.append(text + " | ");
}
builder.append("\r\n");
}
}
}
}
//保存数据至.txt文档
FileWriter fw = new FileWriter("output/ExtractTable.txt");
fw.write(builder.toString());
fw.flush();
fw.close();
}
}
表格信息提取效果如下:
猜你喜欢
- 2024-10-19 PDF转word工具分享!这5个转换工具,超级好用!
- 2024-10-19 电子书格式转换器|支持ePub、Azw3、Mobi、Doc、PDF、TXT文件
- 2024-10-19 扫呀 js 控制扫描仪,支持国产系统、ocr,pdf 导出的免费工具来了
- 2024-10-19 java如何生成动态Word文件(java动态生成图片)
- 2024-10-19 Java 将word文档转换为PNG、XPS、RTF等格式
- 2024-10-19 word转pdf软件有哪些?这几个方法教你轻松转换
- 2024-10-19 Python Web开发中Excel转PDF文件(pythonword转excel)
- 2024-10-19 Java 转换PDF为图片时设置图片的背景透明度
- 2024-10-19 Stimulsoft v2019.2.3发布,HTML文本导出为PDF格式不再是难题
- 2024-10-19 Spire.Doc for Java 10.6.0 增强了 Word 到 PDF 和 HTML 的转换
你 发表评论:
欢迎- 最近发表
-
- Java常量定义防暴指南:从"杀马特"到"高富帅"的华丽转身
- Java接口设计原则与实践:优雅编程的艺术
- java 包管理、访问修饰符、static/final关键字
- Java工程师的代码规范与最佳实践:优雅代码的艺术
- 编写一个java程序(编写一个Java程序计算并输出1到n的阶乘)
- Mycat的搭建以及配置与启动(mycat部署)
- Weblogic 安装 -“不是有效的 JDK Java 主目录”解决办法
- SpringBoot打包部署解析:jar包的生成和结构
- 《Servlet》第05节:创建第一个Servlet程序(HelloSevlet)
- 你认为最简单的单例模式,东西还挺多
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)