2021-08-02 23:42:52 +08:00
|
|
|
|
[English](README.md) | 简体中文
|
2021-06-10 14:24:59 +08:00
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
# PP-Structure
|
2021-06-10 14:24:59 +08:00
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
PP-Structure是一个可用于复杂文档结构分析和处理的OCR工具包,主要特性如下:
|
|
|
|
|
- 支持对图片形式的文档进行版面分析,可以划分**文字、标题、表格、图片以及列表**5类区域(与Layout-Parser联合使用)
|
|
|
|
|
- 支持文字、标题、图片以及列表区域提取为文字字段(与PP-OCR联合使用)
|
|
|
|
|
- 支持表格区域进行结构化分析,最终结果输出Excel文件
|
|
|
|
|
- 支持python whl包和命令行两种方式,简单易用
|
|
|
|
|
- 支持版面分析和表格结构化两类任务自定义训练
|
|
|
|
|
- 总模型大小仅有18.6M(持续优化)
|
2021-06-10 14:24:59 +08:00
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
## 1. 效果展示
|
2021-06-10 14:24:59 +08:00
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
<img src="../doc/table/ppstructure.GIF" width="100%"/>
|
2021-08-02 21:02:01 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
## 2. 安装
|
2021-08-02 21:02:01 +08:00
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
### 2.1 安装依赖
|
2021-08-02 21:02:01 +08:00
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
- **(1) 安装PaddlePaddle**
|
2021-08-02 21:02:01 +08:00
|
|
|
|
|
|
|
|
|
```bash
|
2021-08-02 23:42:52 +08:00
|
|
|
|
pip3 install --upgrade pip
|
2021-08-02 21:02:01 +08:00
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
# GPU安装
|
2021-08-03 08:36:21 +08:00
|
|
|
|
python3 -m pip install paddlepaddle-gpu==2.1.1 -i https://mirror.baidu.com/pypi/simple
|
2021-08-02 21:02:01 +08:00
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
# CPU安装
|
2021-08-03 08:36:21 +08:00
|
|
|
|
python3 -m pip install paddlepaddle==2.1.1 -i https://mirror.baidu.com/pypi/simple
|
2021-08-02 21:02:01 +08:00
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
# 更多需求,请参照[安装文档](https://www.paddlepaddle.org.cn/install/quick)中的说明进行操作。
|
2021-08-02 21:02:01 +08:00
|
|
|
|
```
|
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
- **(2) 安装 Layout-Parser**
|
2021-08-02 17:04:53 +08:00
|
|
|
|
|
2021-08-02 21:02:01 +08:00
|
|
|
|
```bash
|
2021-08-02 23:42:52 +08:00
|
|
|
|
pip3 install -U premailer paddleocr https://paddleocr.bj.bcebos.com/whl/layoutparser-0.0.0-py3-none-any.whl
|
2021-08-02 21:02:01 +08:00
|
|
|
|
```
|
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
### 2.2 安装PaddleOCR(包含PP-OCR和PP-Structure)
|
|
|
|
|
|
|
|
|
|
- **(1) PIP快速安装PaddleOCR whl包(仅预测)**
|
|
|
|
|
|
2021-08-02 21:02:01 +08:00
|
|
|
|
```bash
|
2021-08-03 08:36:21 +08:00
|
|
|
|
pip install "paddleocr>=2.2" # 推荐使用2.2+版本
|
2021-08-02 21:02:01 +08:00
|
|
|
|
```
|
2021-08-02 17:04:53 +08:00
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
- **(2) 完整克隆PaddleOCR源码(预测+训练)**
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
【推荐】git clone https://github.com/PaddlePaddle/PaddleOCR
|
|
|
|
|
|
|
|
|
|
#如果因为网络问题无法pull成功,也可选择使用码云上的托管:
|
|
|
|
|
git clone https://gitee.com/paddlepaddle/PaddleOCR
|
|
|
|
|
|
|
|
|
|
#注:码云托管代码可能无法实时同步本github项目更新,存在3~5天延时,请优先使用推荐方式。
|
2021-07-29 11:51:28 +08:00
|
|
|
|
```
|
2021-06-10 14:24:59 +08:00
|
|
|
|
|
|
|
|
|
|
2021-08-03 10:31:18 +08:00
|
|
|
|
## 3. PP-Structure 快速开始
|
2021-08-02 23:42:52 +08:00
|
|
|
|
|
|
|
|
|
### 3.1 命令行使用(默认参数,极简)
|
2021-06-10 14:24:59 +08:00
|
|
|
|
|
2021-07-29 11:51:28 +08:00
|
|
|
|
```bash
|
2021-08-02 17:04:53 +08:00
|
|
|
|
paddleocr --image_dir=../doc/table/1.png --type=structure
|
2021-06-23 12:45:05 +08:00
|
|
|
|
```
|
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
### 3.2 Python脚本使用(自定义参数,灵活)
|
2021-06-10 14:24:59 +08:00
|
|
|
|
|
|
|
|
|
```python
|
2021-06-23 12:28:32 +08:00
|
|
|
|
import os
|
2021-06-10 14:24:59 +08:00
|
|
|
|
import cv2
|
2021-08-02 17:04:53 +08:00
|
|
|
|
from paddleocr import PPStructure,draw_structure_result,save_structure_res
|
2021-06-10 14:24:59 +08:00
|
|
|
|
|
2021-08-02 17:04:53 +08:00
|
|
|
|
table_engine = PPStructure(show_log=True)
|
2021-06-10 14:24:59 +08:00
|
|
|
|
|
2021-06-23 12:28:32 +08:00
|
|
|
|
save_folder = './output/table'
|
2021-06-10 14:24:59 +08:00
|
|
|
|
img_path = '../doc/table/1.png'
|
|
|
|
|
img = cv2.imread(img_path)
|
|
|
|
|
result = table_engine(img)
|
2021-08-02 17:04:53 +08:00
|
|
|
|
save_structure_res(result, save_folder,os.path.basename(img_path).split('.')[0])
|
2021-06-23 12:28:32 +08:00
|
|
|
|
|
2021-06-10 14:24:59 +08:00
|
|
|
|
for line in result:
|
2021-08-02 17:22:31 +08:00
|
|
|
|
line.pop('img')
|
2021-06-10 14:24:59 +08:00
|
|
|
|
print(line)
|
|
|
|
|
|
|
|
|
|
from PIL import Image
|
|
|
|
|
|
2021-07-29 11:51:28 +08:00
|
|
|
|
font_path = '../doc/fonts/simfang.ttf' # PaddleOCR下提供字体包
|
2021-06-10 14:24:59 +08:00
|
|
|
|
image = Image.open(img_path).convert('RGB')
|
2021-08-02 17:04:53 +08:00
|
|
|
|
im_show = draw_structure_result(image, result,font_path=font_path)
|
2021-06-10 14:24:59 +08:00
|
|
|
|
im_show = Image.fromarray(im_show)
|
|
|
|
|
im_show.save('result.jpg')
|
|
|
|
|
```
|
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
### 3.3 返回结果说明
|
2021-08-03 11:07:30 +08:00
|
|
|
|
PP-Structure的返回结果为一个dict组成的list,示例如下
|
2021-08-01 16:46:43 +08:00
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[
|
2021-08-02 23:42:52 +08:00
|
|
|
|
{ 'type': 'Text',
|
|
|
|
|
'bbox': [34, 432, 345, 462],
|
|
|
|
|
'res': ([[36.0, 437.0, 341.0, 437.0, 341.0, 446.0, 36.0, 447.0], [41.0, 454.0, 125.0, 453.0, 125.0, 459.0, 41.0, 460.0]],
|
2021-08-01 16:46:43 +08:00
|
|
|
|
[('Tigure-6. The performance of CNN and IPT models using difforen', 0.90060663), ('Tent ', 0.465441)])
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
```
|
|
|
|
|
dict 里各个字段说明如下
|
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
| 字段 | 说明 |
|
2021-08-01 16:46:43 +08:00
|
|
|
|
| --------------- | -------------|
|
|
|
|
|
|type|图片区域的类型|
|
|
|
|
|
|bbox|图片区域的在原图的坐标,分别[左上角x,左上角y,右下角x,右下角y]|
|
|
|
|
|
|res|图片区域的OCR或表格识别结果。<br> 表格: 表格的HTML字符串; <br> OCR: 一个包含各个单行文字的检测坐标和识别结果的元组|
|
|
|
|
|
|
2021-06-10 14:24:59 +08:00
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
### 3.4 参数说明
|
2021-07-29 11:51:28 +08:00
|
|
|
|
|
|
|
|
|
| 字段 | 说明 | 默认值 |
|
|
|
|
|
| --------------- | ---------------------------------------- | ------------------------------------------- |
|
|
|
|
|
| output | excel和识别结果保存的地址 | ./output/table |
|
|
|
|
|
| table_max_len | 表格结构模型预测时,图像的长边resize尺度 | 488 |
|
|
|
|
|
| table_model_dir | 表格结构模型 inference 模型地址 | None |
|
|
|
|
|
| table_char_type | 表格结构模型所用字典地址 | ../ppocr/utils/dict/table_structure_dict.tx |
|
|
|
|
|
|
2021-06-10 17:17:46 +08:00
|
|
|
|
大部分参数和paddleocr whl包保持一致,见 [whl包文档](../doc/doc_ch/whl.md)
|
|
|
|
|
|
2021-08-02 17:22:31 +08:00
|
|
|
|
运行完成后,每张图片会在`output`字段指定的目录下有一个同名目录,图片里的每个表格会存储为一个excel,图片区域会被裁剪之后保存下来,excel文件和图片名名为表格在图片里的坐标。
|
2021-07-29 11:51:28 +08:00
|
|
|
|
|
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
## 4. PP-Structure Pipeline介绍
|
2021-07-29 11:51:28 +08:00
|
|
|
|
|
|
|
|
|
![pipeline](../doc/table/pipeline.jpg)
|
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
在PP-Structure中,图片会先经由Layout-Parser进行版面分析,在版面分析中,会对图片里的区域进行分类,包括**文字、标题、图片、列表和表格**5类。对于前4类区域,直接使用PP-OCR完成对应区域文字检测与识别。对于表格类区域,经过表格结构化处理后,表格图片转换为相同表格样式的Excel文件。
|
2021-07-29 11:51:28 +08:00
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
### 4.1 版面分析
|
2021-07-29 11:51:28 +08:00
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
版面分析对文档数据进行区域分类,其中包括版面分析工具的Python脚本使用、提取指定类别检测框、性能指标以及自定义训练版面分析模型,详细内容可以参考[文档](layout/README_ch.md)。
|
2021-07-29 11:51:28 +08:00
|
|
|
|
|
2021-08-03 10:33:59 +08:00
|
|
|
|
### 4.2 表格识别
|
2021-07-29 11:51:28 +08:00
|
|
|
|
|
2021-08-03 10:33:59 +08:00
|
|
|
|
表格识别将表格图片转换为excel文档,其中包含对于表格文本的检测和识别以及对于表格结构和单元格坐标的预测,详细说明参考[文档](table/README_ch.md)
|
2021-07-29 11:51:28 +08:00
|
|
|
|
|
2021-08-02 23:42:52 +08:00
|
|
|
|
## 5. 预测引擎推理(与whl包效果相同)
|
2021-07-29 11:51:28 +08:00
|
|
|
|
|
|
|
|
|
使用如下命令即可完成预测引擎的推理
|
|
|
|
|
|
|
|
|
|
```python
|
2021-08-02 21:02:01 +08:00
|
|
|
|
cd ppstructure
|
2021-08-02 19:42:10 +08:00
|
|
|
|
|
|
|
|
|
# 下载模型
|
|
|
|
|
mkdir inference && cd inference
|
|
|
|
|
# 下载超轻量级中文OCR模型的检测模型并解压
|
|
|
|
|
wget https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_det_infer.tar && tar xf ch_ppocr_mobile_v2.0_det_infer.tar
|
|
|
|
|
# 下载超轻量级中文OCR模型的识别模型并解压
|
|
|
|
|
wget https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_rec_infer.tar && tar xf ch_ppocr_mobile_v2.0_rec_infer.tar
|
|
|
|
|
# 下载超轻量级英文表格英寸模型并解压
|
|
|
|
|
wget https://paddleocr.bj.bcebos.com/dygraph_v2.0/table/en_ppocr_mobile_v2.0_table_structure_infer.tar && tar xf en_ppocr_mobile_v2.0_table_structure_infer.tar
|
|
|
|
|
cd ..
|
|
|
|
|
|
2021-08-03 12:35:17 +08:00
|
|
|
|
python3 predict_system.py --det_model_dir=inference/ch_ppocr_mobile_v2.0_det_infer --rec_model_dir=inference/ch_ppocr_mobile_v2.0_rec_infer --table_model_dir=inference/en_ppocr_mobile_v2.0_table_structure_infer --image_dir=../doc/table/1.png --rec_char_dict_path=../ppocr/utils/ppocr_keys_v1.txt --table_char_dict_path=../ppocr/utils/dict/table_structure_dict.txt --rec_char_type=ch --output=../output/table --vis_font_path=../doc/fonts/simfang.ttf
|
2021-07-29 11:51:28 +08:00
|
|
|
|
```
|
2021-08-02 19:42:10 +08:00
|
|
|
|
运行完成后,每张图片会在`output`字段指定的目录下有一个同名目录,图片里的每个表格会存储为一个excel,图片区域会被裁剪之后保存下来,excel文件和图片名名为表格在图片里的坐标。
|
2021-07-29 11:51:28 +08:00
|
|
|
|
|
2021-07-29 16:12:44 +08:00
|
|
|
|
**Model List**
|
2021-06-10 17:17:46 +08:00
|
|
|
|
|
2021-07-29 11:51:28 +08:00
|
|
|
|
|模型名称|模型简介|配置文件|推理模型大小|下载地址|
|
|
|
|
|
| --- | --- | --- | --- | --- |
|
2021-08-02 23:42:52 +08:00
|
|
|
|
|en_ppocr_mobile_v2.0_table_structure|英文表格场景的表格结构预测|[table_mv3.yml](../configs/table/table_mv3.yml)|18.6M|[推理模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/table/en_ppocr_mobile_v2.0_table_structure_infer.tar) |
|