PaddleOCR 介绍及部署(paddleocr 安装)
liuian 2025-06-30 17:59 5 浏览
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)。
相关推荐
- 【开源推荐】给大家推荐个基于ChatGPT的PHP开发库 openai-php-api
-
有了这个库大家就可以愉快的使用PHP对接chatGPT的官方接口了,至于对接了官方接口想要做什么就看你自己的啦环境要求PHP7.4或以上composer1.6.5以上支持框架Laravel、Sym...
- 3个最流行的大模型应用开发框架【LLM】
-
随着人工智能的能力,特别是大型语言模型(LLM)的不断发展和演变,开发人员正在寻求将AI功能整合到他们的应用程序中。虽然文本完成和摘要等简单任务可以通过直接调用OpenAI或Coher...
- 都说PHP性能差,但PHP性能真的差吗?
-
今天本能是想测试一个PDO持久化,会不会带来会话混乱的问题先贴一下PHP代码,代码丑了点,但是坚持能run就行,反正就是做个测试。<?php$dsn='mysql:host=l...
- saas介绍和原理 · laravel-独立站-商城SaaS – 湾区梁工
-
SaaS就是多租户,一个应用可以分给很多用户使用,而应用只需要维护一个。那么应用就需要做好各种资源的隔离(数据库,文件,缓存,队列,后台,命令行等等)。有两种类型的多租户SaaS形式:1,单数据库Sa...
- 3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?
-
引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...
- pip 2(根细胞吸收水借助pip2)
-
pip-h#-helppipdownload#下载.whl文件,然后是可以安装的UV:Python包管理神器-比pip快100倍安装方法Windows:1powershe...
- 想买《辐射4》的Pip-Boy特别版?那你可得抓紧点
-
今年秋天玩家就能够玩到《辐射4(Fallout4)》,而且还可以边玩这款游戏边把真实的Pip-Boy穿戴装置套在手上。最近,这款游戏的Pip-Boy特殊版本已经开放玩家在百思买、沃尔玛以及GameS...
- PaddleOCR 介绍及部署(paddleocr 安装)
-
PaddleOCR是由百度飞桨(PaddlePaddle)团队开发的开源OCR工具包,凭借其高精度、多场景适应性和易用性,成为目前最受欢迎的光学字符识别工具之一。以下是其核心特点与技术亮点:一、...
- 从需求到技术落地:AI产品经理的技术同理心修炼
-
在当今快速发展的AI时代,产品经理的角色不再局限于需求收集与规划,还需要深入理解技术实现的边界与成本。本文以UnityML-Agents环境配置与寻路Demo实战为例,探讨AI产品经理如何通过亲身体...
- 在windows上设置python的环境(windows配置python环境)
-
上文安装好了python,再具体说下python语言的相关环境。#01关于PythonPython是一个高级别的、边运行边解释的、动态类型的编程语言,以简洁的语法、强大的功能和丰富的资源库而闻名。...
- uv——Python开发栈中的高效全能小工具
-
每天写Python代码的同学,肯定都离不开pip、virtualenv、Poetry等基础工具,但是对这些工具可能是又恨又离不开。那么有什么好的替代呢,虫虫今天就给大家介绍一个替代他们的小工具uv,一...
- 数据驱动型Python应用开发框架:Taipy
-
1.介绍Taipy是一个用于构建数据驱动应用的Python框架。它允许开发者快速创建交互式数据应用,支持数据可视化、数据处理和自动化工作流。1.1Taipy核心特性低代码/无代码GUI开发数据...
- 推荐这几个Python实战项目,瞬间读懂Python!
-
推荐这几个Python实战项目,瞬间读懂Python!Python这玩意儿,说难不难,说简单吧也不是那么容易。我琢磨着,光看书学理论可不行,得动手写点东西才能真正掌握。今儿个我就给大伙儿推荐几个实战项...
- Python项目源码加密部署方案(python源码加密工具)
-
保护Python代码的几种方式对代码进行混淆以降低源码可读性将py文件编译为二进制pyc文件使用Pyinstaller打包源码为二进制可执行文件使用PyArmor加密脚本将py/py...
- 史上最全!近万字梳理Python 开发必备的 os 模块(建议收藏)
-
点赞、收藏、加关注,下次找我不迷路一、开篇本文将带你深入探索os模块的核心功能,通过大量实际案例和代码示例,助你彻底掌握这个Python开发的必备神器。全文近万字,建议收藏后慢慢消化,用的时...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
python使用fitz模块提取pdf中的图片
-
系统C盘清理:微信PC端文件清理,扩大C盘可用空间步骤
-
10款高性能NAS丨双十一必看,轻松搞定虚拟机、Docker、软路由
-
- 最近发表
-
- 【开源推荐】给大家推荐个基于ChatGPT的PHP开发库 openai-php-api
- 3个最流行的大模型应用开发框架【LLM】
- 都说PHP性能差,但PHP性能真的差吗?
- saas介绍和原理 · laravel-独立站-商城SaaS – 湾区梁工
- 3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?
- pip 2(根细胞吸收水借助pip2)
- 想买《辐射4》的Pip-Boy特别版?那你可得抓紧点
- PaddleOCR 介绍及部署(paddleocr 安装)
- 从需求到技术落地:AI产品经理的技术同理心修炼
- 在windows上设置python的环境(windows配置python环境)
- 标签列表
-
- 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)
- table.render (33)
- uniapp textarea (33)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)