百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

PaddleOCR 介绍及部署(paddleocr 安装)

liuian 2025-06-30 17:59 22 浏览

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)。


相关推荐

python环境怎么搭建?小白看完就会!简简单单

很多小伙伴安装了python不会搭建环境,看完这个你就会了Python可应用于多平台包括Linux和MacOSX。你可以通过终端窗口输入"python"命令来查看本地是否...

手把手教本地部署Xinference + deepseek-R1、reranker-v2、bge-m3

Xinference作为本地AI推理框架,相较于Ollama和其他推理方案,有以下几个核心优势:1.多模型支持。Xinference兼容大量LLM(大语言模型),不仅支持LLaMA...

Windows 10下使用编译并使用openCV

1.Windows系统下OpenCV及第三方库文件的使用与下载如果没有特殊要求,在Windows系统下可以直接使用OpenCV的预编译版本。在github的opencv项目release中选择相应r...

Windows环境CMake学习笔记(一)_windows下cmake使用

前言CMake是C++的必学部分,本篇文章从安装环境开始,通过使用CMake构建一个最简单的cpp项目和g++直接编译作对比了解CMake的构建过程,为接下来深入学习CMake打下基础。一、系统环境操...

Docker 安装教程_docker安装shinobi

Docker概述与安装&Dockerfile文件一、Docker概述Docker是一个开源的容器化平台,它允许开发者将应用及其依赖打包到轻量级、可移植的容器中,并能在任何支持Docker...

【直播流】RTSP拉流转推RTMP_rtmp推流和rtsp拉流区别

背景:从第三方协调了几路慢直播,直播流的协议有RTSP、FLV和HLS。不过,本方播放工具只能稳定地播放RTMP流。(本次测试环境:Windows10)步骤概述:安装FFmpeg,用于拉流和转码推流。...

Windows常用的一些CMD运行命令_windows使用cmd运行程序

CMD命令:开始->运行->键入cmd或command(在命令行里可以看到系统版本、文件系统版本appwiz.cpl:程序和功能calc:启动计算器certmgr.msc:证书管理实...

JAVA编程环境搭建 JDK与环境变量、Eclipse

1JDK1.1JDK概述JDK是Java语言的软件开发工具包,主要用于移动设备、嵌入式设备上的java应用程序。JDK是整个java开发的核心,它包含了:JAVA开发工具(jdk\bin)基础...

go os/exec 简明教程_go语言os包

Go标准库提供了便利的方法,可以很容易地运行外部命令,一般我们会使用os/exec包下的方法实现执行外部命令以及和外部命令交互。os/exec包装了os.StartProcess方法,更方便的进行输入...

Python内置模块:shutil模块使用教程(文件与目录高级操作实践)

一、shutil模块简介在Python开发中,文件与目录操作是最基础的需求之一。虽然os模块提供了基础的文件系统交互能力,但对于复制、移动、删除目录、归档压缩等复杂操作,shutil模块(Shell...

乌龟冬眠箱湿度监控系统和AI辅助建议功能的实现

|注:本文曾发表在博客园我的个人博客中,转载至此公众号以归档保存。家里小朋友养了一只小乌龟,到了冬天就冬眠了,早早地准备了一个冬眠箱,铺上椰土,在室温低于15℃时,就把小乌龟放到冬眠箱里,不一会儿它...

Python环境安装教程_python安装及环境变量配置

文章目录前言一、安装python运行环境1.官网https://www.python.org下载安装包.exe2.安装python二、python模块下载1.配置pip环境变量2.下载pyth...

Python Windows 11 安装后,CMD界面进入不了Python编译界面的解决

1.Python安装进入官网下载python编译界面PythonReleasePython3.10.4|Python.org2.搜索栏输入cmd,进入命令提示符这时输入python命令提...

Windows命令行command的Shell命令详细解析和语法

CMD命令大全及详细解释和语法CMD命令大全及详细解释和语法MicrosoftWindowsXP[版本5.1.2600]有关某个命令的详细信息,请键入HELP命令名ASSOC显示或修改文...

JDK1.8安装&环境变量配置_java安装jdk配置环境变量

1、下载并安装JDK1.8链接:https://pan.baidu.com/s/1bfceFjfTQvLylu7a3T7fyg?pwd=ydtm提取码:ydtm2、设置环境变量2.1打开“控制面板”...