• PaddleOCR实验过程记录


    一、环境准备

    开始使用_飞桨-源于产业实践的开源深度学习平台

    快速安装:

     检查是否安装成功:

    1. pip install paddlehub -i https://pypi.tuna.tsinghua.edu.cn/simple
    2. #该Module依赖于第三方库shapely、pyclipper,使用该Module之前,请先安装shapely、pyclipper
    3. pip install shapely -i https://pypi.tuna.tsinghua.edu.cn/simple
    4. pip install pyclipper -i https://pypi.tuna.tsinghua.edu.cn/simple

     PaddleHub一键OCR中文识别(超轻量8.1M模型,火爆) - 飞桨AI Studio

    1. import matplotlib.pyplot as plt
    2. import matplotlib.image as mpimg
    3. # 待预测图片
    4. test_img_path = ["./advertisement.jpg", "./pics.jpg", "./identity_card.jpg", "./express.jpg", "./railway_ticket.jpg"]
    5. # 展示其中广告信息图片
    6. img1 = mpimg.imread(test_img_path[0])
    7. plt.figure(figsize=(10,10))
    8. plt.imshow(img1)
    9. plt.axis('off')
    10. plt.show()

     

    二、加载预训练模型

    1. import paddlehub as hub
    2. # 加载移动端预训练模型
    3. # ocr = hub.Module(name="chinese_ocr_db_crnn_mobile")
    4. # 服务端可以加载大模型,效果更好
    5. ocr = hub.Module(name="chinese_ocr_db_crnn_server")

    三、预测

     

    1. import cv2
    2. # 读取测试文件夹test.txt中的照片路径
    3. np_images =[cv2.imread(path+image_path) for image_path in test_img_path]
    4. results = ocr.recognize_text(
    5. images=np_images, # 图片数据,ndarray.shape 为 [H, W, C],BGR格式;
    6. use_gpu=False, # 是否使用 GPU;若使用GPU,请先设置CUDA_VISIBLE_DEVICES环境变量
    7. output_dir='ocr_result', # 图片的保存路径,默认设为 ocr_result;
    8. visualization=True, # 是否将识别结果保存为图片文件;
    9. box_thresh=0.5, # 检测文本框置信度的阈值;
    10. text_thresh=0.5) # 识别中文文本置信度的阈值;
    11. for result in results:
    12. data = result['data']
    13. save_path = result['save_path']
    14. for infomation in data:
    15. print('text: ', infomation['text'], '\nconfidence: ', infomation['confidence'], '\ntext_box_position: ', infomation['text_box_position'])

    recognize_text()接口返回结果results说明:

    • results (list[dict]): 识别结果的列表,列表中每一个元素为 dict,各字段为:
      • data (list[dict]): 识别文本结果,列表中每一个元素为 dict,各字段为:
        • text(str): 识别得到的文本
        • confidence(float): 识别文本结果置信度
        • text_box_position(list): 文本框在原图中的像素坐标,4*2的矩阵,依次表示文本框左下、右下、右上、左上顶点的坐标 如果无识别结果则data为[]
      • save_path (str, optional): 识别结果的保存路径,如不保存图片则save_path为''

    四、服务部署

    第一步:启动PaddleHub Serving

     

    第二步:发送预测请求

    1. import requests
    2. import json
    3. import cv2
    4. import base64
    5. def cv2_to_base64(image):
    6. data = cv2.imencode('.jpg', image)[1]
    7. return base64.b64encode(data.tostring()).decode('utf8')
    8. # 发送HTTP请求
    9. data = {'images':[cv2_to_base64(cv2.imread("D:/OCR/MMOCR/mmocr/demo/highway.jpg"))]}
    10. headers = {"Content-type": "application/json"}
    11. url = "http://127.0.0.1:8866/predict/chinese_ocr_db_crnn_server"
    12. r = requests.post(url=url, headers=headers, data=json.dumps(data))
    13. # 打印预测结果
    14. print(r.json()["results"])

     

     参考:飞桨PaddlePaddle-源于产业实践的开源深度学习平台

  • 相关阅读:
    利用Python+阿里云实现DDNS(动态域名解析)
    python面经(滴滴、理想、momenta)
    【gitlab】本地项目上传gitlab
    vscode因为大文件而无限崩溃的问题,窗口意外终止(原因:“oom“,代码:“-536870904“
    如何全面的理解APS自动排产系统?
    Himall商城安装帮助类AES加密解密(2)
    【C语言】popen()函数详解
    Lab: page tables
    XGB(有监督学习)和多维时序模型结合——预测风电出力
    uniapp确认提示框;uniapp判断输入框值是否符合正常手机号,身份证号
  • 原文地址:https://blog.csdn.net/u011788214/article/details/126382644