前端开发入门到精通的在线学习网站

网站首页 > 资源文章 正文

PaddleOCR 介绍及部署(paddleocr进行部署)

qiguaw 2025-06-10 00:35:39 资源文章 8 ℃ 0 评论

PaddleOCR 是由百度飞桨(PaddlePaddle)团队开发的开源 OCR 工具包,凭借其高精度、多场景适应性和易用性,成为目前最受欢迎的光学字符识别工具之一。以下是其核心特点与技术亮点:


一、核心优势

  1. 领先的识别性能

高精度模型:最新版 PP-OCRv4 在检测和识别任务中,Hmean 值从 v3 的 57.99% 提升至 62.24%,推理时间仅增加 0.2ms(Intel Xeon CPU 实测)。

多语言支持:覆盖 80+ 种语言,包括中文、英文、日文、韩文等,并支持竖排文本、手写体及复杂版面分析。

模型轻量化:基于 MobileNetV3、PP-LCNet 等轻量级网络,兼顾速度与精度,适合移动端部署。

  1. 技术创新与全流程支持

前沿算法集成:如 SVTRv2(场景文本识别)和 SLANet-LCNetV2(表格识别),显著提升复杂场景下的识别效果。

低代码开发:通过 paddlex 库提供 17 个预训练模型的一键调用,支持从数据标注到推理部署的全流程开发。

文档智能分析:PP-ChatOCRv3-doc 结合大语言模型(如文心 ERNIE),信息抽取准确率较上一版提升 6%,新增图像矫正、公式识别等功能。

  1. 跨平台与国产化适配

支持 NVIDIA GPU、昆仑芯、昇腾、寒武纪等硬件,优化推理速度。

提供 OpenVINO、ONNX 等推理引擎适配,满足工业级部署需求。


二、使用场景与案例

  1. 通用文字识别

支持图片、PDF 等多格式输入,可快速提取文字内容。例如,通过 3 行代码实现图像识别:

python

复制

from paddleocr import PaddleOCR ocr = PaddleOCR(use_angle_cls=True, lang="ch") result = ocr.ocr("test.jpg", cls=True)


  1. 文档结构化处理

解析合同、票据等复杂版式文档,自动提取关键字段(如金额、日期)。

表格识别支持跨行合并单元格,输出结构化数据。

  1. 工业与学术研究

支持自定义模型训练,通过数据增强(如 CopyPaste、TextRotNet)优化特定场景效果。

提供零代码训练工具,用户仅需上传标注数据即可完成模型迭代。


以下是 PaddleOCR 本地化部署的详细步骤,涵盖环境配置、模型部署及常见问题处理,适用于 Windows/Linux 系统:


本地部署

安装 PaddlePaddle 框架

  • CPU 版本
  • bash
  • 复制
  • python -m pip install paddlepaddle -i https://mirror.baidu.com/pypi/simple[2,6](@ref)
  • GPU 版本(需 CUDA 11.6+ 和 cuDNN 8.4+):
  • bash
  • 复制
  • python -m pip install paddlepaddle-gpu==2.6.1 -i https://mirror.baidu.com/pypi/simple[3,4](@ref)
  • 验证安装:
  • python
  • 复制
  • import paddle paddle.utils.run_check() # 输出 "PaddlePaddle is installed successfully!" 即成功[3](@ref)

安装 PaddleOCR 及依赖

  1. 克隆仓库与依赖安装
  2. bash
  3. 复制
  4. git clone https://github.com/PaddlePaddle/PaddleOCR.git cd PaddleOCR pip install -r requirements.txt -i https://mirror.baidu.com/pypi/simple[2,6](@ref)
  5. 安装 PaddleOCR 包
  6. bash
  7. 复制
  8. pip install paddleocr==2.7.0.0 --upgrade[3,4](@ref)

模型部署与配置

  1. 下载预训练模型
  2. 检测模型
  3. bash
  4. 复制
  5. wget https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_det_infer.tar tar xf ch_ppocr_server_v2.0_det_infer.tar -C ./inference/[6](@ref)
  6. 识别模型:同理下载 ch_ppocr_server_v2.0_rec_infer.tar。
  7. 修改配置文件
  8. 编辑 deploy/hubserving/ocr_system/params.py,更新模型路径:
  9. python
  10. 复制
  11. cfg.det_model_dir = "./inference/ch_ppocr_server_v2.0_det_infer/" cfg.rec_model_dir = "./inference/ch_ppocr_server_v2.0_rec_infer/"[2,6](@ref)

启动 OCR 服务

  1. 命令行启动
  2. 轻量模型(移动端)
  3. bash
  4. 复制
  5. hub serving start -m chinese_ocr_db_crnn_mobile[2](@ref)
  6. 高精度模型(服务器端)
  7. bash
  8. 复制
  9. hub serving start -m chinese_ocr_db_crnn_server[2](@ref)
  10. 代码调用示例
  11. python
  12. 复制
  13. from paddleocr import PaddleOCR ocr = PaddleOCR(use_angle_cls=True, use_gpu=False) # use_gpu=True启用GPU加速[4](@ref) result = ocr.ocr("test.jpg", cls=True) for line in result: print(line[1][0]) # 输出识别文本及坐标[4](@ref)

常见问题处理

  1. GLIBCXX 版本过低
  2. 下载高版本 libstdc++.so.6.0.26,替换系统库并重建软链接。
  3. 依赖冲突
  4. Numpy 版本:强制安装指定版本 pip install numpy==1.23.4。
  5. urllib3 报错:降级至 1.26.6。
  6. OMP 错误(Windows)
  7. 删除冲突的 OpenMP 库(如 libiomp5md.dll)。


Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表