PaddleOCR加载chinese_ocr_db_crnn_modile模型进行中英文混合预测(Http服务)实践

9 篇文章 0 订阅
4 篇文章 2 订阅
1. 环境搭建

参考:《PaddleOCR加载chinese_ocr_db_crnn_server模型进行中英文混合预测(命令行)实践

2. 服务端部署
hub serving start -m chinese_ocr_db_crnn_mobile -p 8866
3. 客户端访问
# coding: utf8
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"])
4. 将图像识别服务部署到Flask上

先参考《Flask开发实践》或《Flask入门
在此基础上进行了以下修改:

文件routes.py增加的内容

import base64
import json
import os
import cv2
import requests
from werkzeug.utils import secure_filename


# OCR测试
@webapp.route('/ocr', methods=['POST', 'GET'])
def ocr():
    basepath = os.path.dirname(__file__)  # 当前文件所在路径
    print(request.method)
    if request.method == 'POST':
        f = request.files['file']
        upload_path = os.path.join(basepath, 'static/uploads', secure_filename(f.filename))  # 注意:没有的文件夹要先创建
        f.save(upload_path)
        return redirect(url_for('ocr_result', pic_name=f.filename))
    else:
        return render_template('ocr.html')


# OCR测试结果
@webapp.route('/ocr/<pic_name>', methods=['POST', 'GET'])
def ocr_result(pic_name):
    basepath = os.path.dirname(__file__)  # 当前文件所在路径
    print(request.method)
    if pic_name != "":
        upload_path = os.path.join(basepath, 'static/uploads', secure_filename(pic_name))
        data = {'images': [cv2_to_base64(cv2.imread(upload_path))]}
        headers = {"Content-type": "application/json"}
        url = "http://127.0.0.1:8866/predict/chinese_ocr_db_crnn_mobile"
        # 图像识别服务: hub.exe serving start -m chinese_ocr_db_crnn_mobile -p 8866
        r = requests.post(url=url, headers=headers, data=json.dumps(data))
        # 打印预测结果
        results = r.json()["results"][0]["data"]

        return render_template('ocr.html', results=results, file=upload_path.replace(basepath, ''))
    else:
        return render_template('ocr.html')


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

新建模板文件ocr.html

<!DOCTYPE html>
<html >
<head>
    <meta charset="UTF-8">
        <title>图像识别测试页</title>
</head>
<body>
    <h1>图像识别测试页</h1>
    <form action="/ocr" enctype="multipart/form-data" method="post">
        <input type="file" name="file">
        <input type="submit" value="提交">
    </form>
    <h1>识别结果</h1>
    <img src="{{ file }}">
    {% for result in results %}
        <table>
            <tr valign="top">
                <td>[置信度] {{ (result.confidence*100) | round(2) }}%, [文字内容] {{ result.text }}</td>
            </tr>
        </table>
    {% endfor %}
    {{ result }}
</body>
</html>
5. 运行效果

先上传图片
在这里插入图片描述

提交后显示图片内容和识别结果
在这里插入图片描述

【参考文档】
PaddleHub一键OCR中文识别

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

皓月如我

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值