PaddleOCR 介绍及部署(paddleocr 安装)
liuian 2025-06-30 17:59 22 浏览
PaddleOCR 是由百度飞桨(PaddlePaddle)团队开发的开源 OCR 工具包,凭借其高精度、多场景适应性和易用性,成为目前最受欢迎的光学字符识别工具之一。以下是其核心特点与技术亮点:
一、核心优势
- 领先的识别性能
高精度模型:最新版 PP-OCRv4 在检测和识别任务中,Hmean 值从 v3 的 57.99% 提升至 62.24%,推理时间仅增加 0.2ms(Intel Xeon CPU 实测)。
多语言支持:覆盖 80+ 种语言,包括中文、英文、日文、韩文等,并支持竖排文本、手写体及复杂版面分析。
模型轻量化:基于 MobileNetV3、PP-LCNet 等轻量级网络,兼顾速度与精度,适合移动端部署。
- 技术创新与全流程支持
前沿算法集成:如 SVTRv2(场景文本识别)和 SLANet-LCNetV2(表格识别),显著提升复杂场景下的识别效果。
低代码开发:通过 paddlex 库提供 17 个预训练模型的一键调用,支持从数据标注到推理部署的全流程开发。
文档智能分析:PP-ChatOCRv3-doc 结合大语言模型(如文心 ERNIE),信息抽取准确率较上一版提升 6%,新增图像矫正、公式识别等功能。
- 跨平台与国产化适配
支持 NVIDIA GPU、昆仑芯、昇腾、寒武纪等硬件,优化推理速度。
提供 OpenVINO、ONNX 等推理引擎适配,满足工业级部署需求。
二、使用场景与案例
- 通用文字识别
支持图片、PDF 等多格式输入,可快速提取文字内容。例如,通过 3 行代码实现图像识别:
python
复制
from paddleocr import PaddleOCR ocr = PaddleOCR(use_angle_cls=True, lang="ch") result = ocr.ocr("test.jpg", cls=True)
- 文档结构化处理
解析合同、票据等复杂版式文档,自动提取关键字段(如金额、日期)。
表格识别支持跨行合并单元格,输出结构化数据。
- 工业与学术研究
支持自定义模型训练,通过数据增强(如 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 及依赖
- 克隆仓库与依赖安装
- bash
- 复制
- 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)
- 安装 PaddleOCR 包
- bash
- 复制
- pip install paddleocr==2.7.0.0 --upgrade[3,4](@ref)
模型部署与配置
- 下载预训练模型
- 检测模型:
- bash
- 复制
- 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)
- 识别模型:同理下载 ch_ppocr_server_v2.0_rec_infer.tar。
- 修改配置文件
- 编辑 deploy/hubserving/ocr_system/params.py,更新模型路径:
- python
- 复制
- 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 服务
- 命令行启动
- 轻量模型(移动端):
- bash
- 复制
- hub serving start -m chinese_ocr_db_crnn_mobile[2](@ref)
- 高精度模型(服务器端):
- bash
- 复制
- hub serving start -m chinese_ocr_db_crnn_server[2](@ref)
- 代码调用示例
- python
- 复制
- 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)
常见问题处理
- GLIBCXX 版本过低
- 下载高版本 libstdc++.so.6.0.26,替换系统库并重建软链接。
- 依赖冲突
- Numpy 版本:强制安装指定版本 pip install numpy==1.23.4。
- urllib3 报错:降级至 1.26.6。
- OMP 错误(Windows)
- 删除冲突的 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打开“控制面板”...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
飞牛OS入门安装遇到问题,如何解决?
-
系统C盘清理:微信PC端文件清理,扩大C盘可用空间步骤
-
10款高性能NAS丨双十一必看,轻松搞定虚拟机、Docker、软路由
-
- 最近发表
-
- python环境怎么搭建?小白看完就会!简简单单
- 手把手教本地部署Xinference + deepseek-R1、reranker-v2、bge-m3
- Windows 10下使用编译并使用openCV
- Windows环境CMake学习笔记(一)_windows下cmake使用
- Docker 安装教程_docker安装shinobi
- 【直播流】RTSP拉流转推RTMP_rtmp推流和rtsp拉流区别
- Windows常用的一些CMD运行命令_windows使用cmd运行程序
- JAVA编程环境搭建 JDK与环境变量、Eclipse
- go os/exec 简明教程_go语言os包
- Python内置模块:shutil模块使用教程(文件与目录高级操作实践)
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)