paddlehub环境搭建和测试

目录

  • 1.环境搭建
    • [1.1 创建conda环境](#1.1 创建conda环境)
    • [1.2 安装paddlepaddle和paddlehub](#1.2 安装paddlepaddle和paddlehub)
    • [1.3 安装依赖](#1.3 安装依赖)
  • [2. 移动端模型部署](#2. 移动端模型部署)
    • [2.1 安装移动端模型](#2.1 安装移动端模型)
    • [2.2 测试](#2.2 测试)
  • [3. 服务部署](#3. 服务部署)
    • [3.1 启动PaddleHub Serving](#3.1 启动PaddleHub Serving)
    • [3.2 发送预测请求](#3.2 发送预测请求)

1.环境搭建

1.1 创建conda环境

bash 复制代码
conda create --name paddlehub python=3.8
conda activate paddlehub

1.2 安装paddlepaddle和paddlehub

bash 复制代码
pip install paddlepaddle -i https://pypi.tuna.tsinghua.edu.cn/simple
pip install paddlehub -i https://pypi.tuna.tsinghua.edu.cn/simple

1.3 安装依赖

bash 复制代码
pip install shapely pyclipper

2. 移动端模型部署

2.1 安装移动端模型

bash 复制代码
hub install chinese_ocr_db_crnn_mobile

报错1:

增加download函数

bash 复制代码
vim /home/yinsuan/miniconda3/envs/paddlehub/lib/python3.8/site-packages/aistudio_sdk/hub.py 
python 复制代码
def download(url, target_path):
    os.makedirs(os.path.dirname(target_path), exist_ok=True)
    response = requests.get(url, stream=True)
    with open(target_path, 'wb') as f:
        for chunk in response.iter_content(chunk_size=1024):
            if chunk:
                f.write(chunk)
    print(f"Downloaded {url} to {target_path}")

报错2:

bash 复制代码
export PROTOCOL_BUFFERS_PYTHON_IMPLEMENTATION=python

安装成功

2.2 测试

将其中的np.int 修改为int即可

bash 复制代码
vim /home/yinsuan/.paddlehub/modules/chinese_ocr_db_crnn_mobile/module.py
bash 复制代码
hub run chinese_ocr_db_crnn_mobile --input_path "/PATH/TO/IMAGE"

测试成功

3. 服务部署

3.1 启动PaddleHub Serving

bash 复制代码
hub serving start -m chinese_ocr_db_crnn_mobile

3.2 发送预测请求

bash 复制代码
import requests
import json
import cv2
import base64

def cv2_to_base64(image):
    data = cv2.imencode('.jpg', image)[1]
    return base64.b64encode(data.tostring()).decode('utf8')

# 发送HTTP请求
data = {'images':[cv2_to_base64(cv2.imread("/PATH/TO/IMAGE"))]}
headers = {"Content-type": "application/json"}
url = "http://127.0.0.1:8866/predict/chinese_ocr_db_crnn_mobile"
r = requests.post(url=url, headers=headers, data=json.dumps(data))

# 打印预测结果
print(r.json()["results"])

参考:https://www.paddlepaddle.org.cn/hubdetail?name=chinese_ocr_db_crnn_mobile&en_category=TextRecognition

相关推荐
胡耀超3 天前
基于Docker的GPU版本飞桨PaddleOCR部署深度指南(国内镜像)2025年7月底测试好用:从理论到实践的完整技术方案
运维·python·docker·容器·ocr·paddlepaddle·gpu
哈__18 天前
文心一言4.5开源部署指南及文学领域测评
人工智能·ai·文心一言·paddlepaddle
cooldream200921 天前
「源力觉醒 创作者计划」_基于 PaddlePaddle 部署 ERNIE-4.5-0.3B 轻量级大模型实战指南
人工智能·paddlepaddle·文心大模型
云天徽上24 天前
【PaddleOCR】OCR常见关键信息抽取数据集,包含FUNSD、XFUND、WildReceipt等整理,持续更新中......
人工智能·计算机视觉·信息可视化·paddlepaddle·paddleocr·文本识别
Sliphades24 天前
PaddleOCR独立服务:高效OCR一站式解决方案
paddlepaddle·ai ocr
univerbright1 个月前
百度飞桨(PaddlePaddle)案例分享:基于 PaddleOCR 的图像文字提取系统
人工智能·百度·paddlepaddle·paddleocr·图像文字提取
一颗红心丶1 个月前
Windows系统上离线部署Python运行飞桨(PaddlePaddle) OCR服务
windows·python·paddlepaddle
红酒暖心也暖胃1 个月前
PaddleOCR环境安装-踩坑记录
paddlepaddle·paddleocr·踩坑
Zheng.Zeng2 个月前
第一篇:Liunx环境下搭建PaddlePaddle 3.0基础环境(Liunx Centos8.5安装Python3.10+pip3.10)
人工智能·paddlepaddle