[发明专利]一种基于位置关系的PDF表格抽取方法在审
申请号: | 201810142927.7 | 申请日: | 2018-02-11 |
公开(公告)号: | CN110147537A | 公开(公告)日: | 2019-08-20 |
发明(设计)人: | 陈前力;王博远;吴雪军 | 申请(专利权)人: | 鼎复数据科技(北京)有限公司 |
主分类号: | G06F17/24 | 分类号: | G06F17/24 |
代理公司: | 北京康思博达知识产权代理事务所(普通合伙) 11426 | 代理人: | 范国锋;刘冬梅 |
地址: | 100020 北京*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 文本块 表格抽取 基于位置 删除 绝对位置信息 读取 信息对应 重新排列 规整 并合 筛选 融合 行列 | ||
本发明公开了一种基于位置关系的PDF表格抽取方法,该方法中首先整理/读取出PDF文件中的各个文本块信息,将由多个文本块并合形成的融合文本块再次拆分回多个文本块,并按照绝对位置信息重新排列所有的文本块;根据行间距和标志性序号,从中筛选出待处理表格;再对该待处理表格做进一步处理,如删除不规整表格,调整各个文本块的宽度,删除多余的行列等,最终得到与PDF中信息对应性良好的可编辑表格。
技术领域
本发明涉及PDF文件处理方法领域,具体涉及一种基于位置关系的PDF表格抽取方法。
背景技术
PDF全称Portable Document Format,是便携文档格式的意思,可以完美表现文件的原始样式(完美保真),不会因为使用的软件、系统,等等东西的不同而产生不同的显示效果,屏幕显示和打印输出就是发布者想要的样子。因此,目前网络上传播的文档大部分是PDF格式文件,但是这给很多从文档中整理表格数据的人群带来了困难,尤其是在金融领域,在财务报告、行业研究报告中,研究员需针对表格做进一步的深度处理,需将pdf中的表格转化成规则的行和列的形式,如Excel表格等可编辑的形式。
目前业内大多数pdf处理工具,基本上都是针对文本的处理,或者转化为doc格式,转化为doc后,虽然能提取出部分表格,但是由于原始pdf表格中的格式样式差异化较大,表格效果不理想,准确率较低,不能满足金融领域中高精度数据的需求。
由于上述原因,本发明人开发设计出一种全新的PDF文本提取方法,尤其是PDF文本中无边框表格的提取方法。
发明内容
为了克服上述问题,本发明人进行了锐意研究,设计出一种基于位置关系的PDF表格抽取方法,该方法中首先整理/读取出PDF文件中的各个文本块信息,将由多个文本块并合形成的融合文本块再次拆分回多个文本块,并按照绝对位置信息重新排列所有的文本块;根据行间距和标志性序号,从中筛选出待处理表格;再对该待处理表格做进一步处理,如删除不规整表格,调整各个文本块的宽度,删除多余的行列等,最终得到与PDF中信息对应性良好的可编辑表格,从而完成本发明。
具体来说,本发明的目的在于提供基于位置关系的PDF表格抽取方法,该方法包括如下步骤:
步骤1:从PDF文件中解析出各个文本块信息;
步骤2:在虚拟内存中,按照PDF文件中的位置信息重新排列各个文本块,形成待处理文本;
步骤3:识别所述待处理文本中各个行的位置信息和字符信息,从中筛选出待处理表格;
步骤4:删除步骤3得到的待处理表格中不规整的表格;
步骤5:调整所述待处理表格中各个文本块的宽度,使得同一列中的各个文本块宽度一致;
步骤6:沿着文本块绘制表格。
其中,所述文本块信息包括该文本块中所有的字符信息和该文本块在PDF文件中的坐标位置信息。
其中,在步骤1之后,在步骤2之前还要对步骤1中的文本块做拆分处理,将需要拆分的文本块拆分成两个或多个文本块。
其中,所述需要拆分的文本块为:存在间距尺寸大于预定值的相邻两个字符的文本块;
从该需要拆分的文本块的所述间距尺寸大于预定值的相邻两个字符之间拆分;
优选地,所述预定值为该PDF文件中一个汉字字符的平均尺寸。
其中,在步骤2中,所述重新排列各个文本块包括把位于同一水平位置上的文本块按从左到右的顺序排成一行,把位于同一竖直位置上的文本块按从上到下的顺序排成一列。
其中,在步骤3中,通过各个行的位置信息判断各个行之间的间距尺寸,通过字符信息判断各个行中是否包含标志性的序号。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于鼎复数据科技(北京)有限公司,未经鼎复数据科技(北京)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810142927.7/2.html,转载请声明来源钻瓜专利网。