【ocr识别003】flask+paddleocr+bootstrap搭建OCR文本推理WEB服务

ops/2024/12/22 18:37:39/

1.欢迎点赞、关注、批评、指正,互三走起来,小手动起来!
2.了解、学习OCR相关技术知识领域,结合日常的场景进行测试、总结。如本文总结的html" title=flask>flask+paddlehtml" title=ocr>ocr+html" title=bootstrap>bootstrap搭建OCR文本推理WEB服务应用示例场景。

文章目录

    • 1.代码结构
    • 2.效果演示
    • 3.接口返回
    • 4.代码详情
      • 4.1 `HTML`代码详情
      • 4.2`Python`代码详情
    • 5.PaddleOCR模型推理参数解释
    • 6.后续展望

1.代码结构

  • 如下图所示:
    在这里插入图片描述

2.效果演示

  • 详情如下:
    在这里插入图片描述

3.接口返回

  • 接口测试效果图
    在这里插入图片描述

  • 返回结果详情部分示例

    {"error_code": "000000","error_msg": "识别成功","filename": "cstp2.png","recognize_time": "5890","result": [{"points": [[14.0,11.0],[108.0,11.0],[108.0,40.0],[14.0,40.0]],"score": 0.979973316192627,"text": "性别:男"},{"points": [[289.0,11.0],[400.0,9.0],[401.0,37.0],[290.0,39.0]],"score": 0.8993546962738037,"text": "住院号:"},{"points": [[677.0,2.0],[713.0,12.0],[707.0,31.0],[672.0,21.0]],"score": 0.6370271444320679,"text": "贝别:"}]
    }
    

4.代码详情

4.1 HTML代码详情

  • html"><!DOCTYPE html>
    <html>
    <meta charset="utf-8">
    <head><title>OCR文字检测识别试运行系统</title><!--静态加载 样式--><link rel="stylesheet" href={{ url_for('static',filename='html" title=bootstrap>bootstrap-3.4.1/css/html" title=bootstrap>bootstrap.min.css') }}></link><link rel="stylesheet" href={{ url_for('static',filename='css/upload.css') }}></link><link rel="stylesheet" href={{ url_for('static',filename='css/36buttons.css') }}></link>
    </head>
    <body>
    <div class="header"><div class="title">【OCR】PP-OCRv3 文字检测识别试运行系统v0.3.0</div>
    </div><ul class="menu"><li><a href="/upload/">通用文本检测识别处理</a></li>
    </ul><div class="content"><!--上传图片文件--><div id="upload_file"><form id="fileForm" action="/upload/" method="POST" enctype="multipart/form-data"><div class="form-group"><input type="file" class="form-control" id="_upload_file" name="upload_file">
    <!--                <label class="sr-only" for="upload_file">上传图片</label>--></br><button id="resetButton" name="resetButton" type="reset" class="button green">重置推理结果</button></div></form></div>
    </div>
    </div><div id="show" style="display: none;"><!--显示上传的图片--><div class="col-md-6" style="border: 2px solid #ddd;"></br><span class="label label-info" style="font-size: 24px;"><<<<<< 原始图片展示 >>>>>> </br></span><!--静态加载 图片, url_for() 动态生成路径 --></br><img id="src_pic_show" src="" alt="Image preview area..." title="preview-img" class="img-responsive"></div><div class="col-md-6" style="border: 2px solid #ddd;"><!--显示识别结果JSON报文列表--></br><span class="label label-info" style="font-size: 24px;"><<<<<< 推理结果详情 >>>>>> </br></span></br><!-- 结果显示区 --><div id="result_show" style="font-size: 28px;">客官,您提交的任务加急推理中......</div></div>
    </div>
    </body>
    </html>
    <script src="https://code.jquery.com/jquery-1.12.4.min.js"></script>
    <script src="http://malsup.github.io/jquery.form.js"></script><script type="text/javascript">var fileInput = document.querySelector('input[type=file]');var previewImg = document.querySelector('img');{#上传图片事件#}fileInput.addEventListener('change', function () {var file = this.files;var reader = new FileReader();//显示预览界面$("#show").css("display", "block");// 监听reader对象的的onload事件,当图片加载完成时,把base64编码賦值给预览图片reader.addEventListener("load", function () {previewImg.src = reader.result;}, false);// 调用reader.readAsDataURL()方法,把图片转成base64reader.readAsDataURL(file);//初始化输出结果信息$("#result_show").html("</br>客官,您提交的任务加急推理中......");{#上传图片识别表单事件,并显示识别结果信息#}{# ajaxSubmit 请求异步响应#}$("#fileForm").ajaxSubmit(function (data) {var inner = '<table border="1"> <thead> <tr> <th>序号</th> <th>文本目标</th> <th>置信度分数</th> </tr> </thead> <tbody>';//循环输出返回结果,响应识别结果为每行列表var inc = 1;for (var i in data['result']) {var text = data['result'][i]['text'];var score = data['result'][i]['score'];inner += "<tr><td>" + inc + "</td>" + "<td>" + text + "</td>" + "<td>" + score + "</td></tr>";inc += 1;}inner += '</tbody></table>'//清空输出结果信息$("#result_show").html("");//添加识别结果信息$("#show").append( inner );});}, false);document.getElementById('resetButton').addEventListener('click', function() {document.getElementById('src_pic_show').src = '';$('#result_show').empty();});
    </script>
    

4.2Python代码详情

  • 源代码
    import json
    import os
    import time
    import numpy as np
    import pandas as pd
    from pyautogui import *
    from paddlehtml" title=ocr>ocr import PaddleOCR
    from PIL import Image, ImageDraw
    from html" title=flask>flask import Flask, render_template, request, jsonify
    # 应用名称,当前py名称,视图函数
    app = Flask(__name__)
    # 相对路径
    BASE_DIR = os.path.dirname(os.path.basename(__name__))# 上传文件路径
    UPLOAD_DIR = os.path.join(os.path.join(BASE_DIR, 'static'), 'upload')def html" title=ocr>ocr_img2text( image ):result_dict = {'result': []}paddlehtml" title=ocr>ocr = PaddleOCR(det_model_dir='./inference/ch_PP-OCRv3_det_infer/',rec_model_dir='./inference/ch_PP-OCRv3_rec_infer/',cls_model_dir='./inference/ch_pphtml" title=ocr>ocr_mobile_v2.0_cls_infer/',use_angle_cls=True, lang="ch", use_gpu=True)if image == "":image = screenshot()  # 使用pyautogui进行截图操作image = np.array(image)else:# 不为空就打开image = Image.open(image).convert('RGB')image = np.array(image)  # 经提醒,需要添加arrayprint( image, type(image) )# 识别图片文件result0 = paddlehtml" title=ocr>ocr.html" title=ocr>ocr( image, cls=True )result = result0[0]# for line in result0:#     for word in line:#         print( word )for index in range(len(result)):line = result[index]p_dict = {}points = line[1]text = line[1][0]score = line[1][1]p_dict['points'] = pointsp_dict['text'] = textp_dict['score'] = scoreresult_dict['result'].append( p_dict )return result_dict@app.route('/')
    def upload_file():return render_template('upload.html')@app.route('/upload/', methods=['GET', 'POST'])
    def upload():if request.method == 'POST':# 每个上传的文件首先会保存在服务器上的临时位置,然后将其实际保存到它的最终位置。filedata = request.files['upload_file']upload_filename = filedata.filenameprint(upload_filename)# 保存文件到指定路径# 目标文件的名称可以是硬编码的,也可以从 ​request.files[file] ​对象的​ filename ​属性中获取。# 但是,建议使用 ​secure_filename()​ 函数获取它的安全版本if not os.path.exists(UPLOAD_DIR):os.makedirs(UPLOAD_DIR)img_path = os.path.join(UPLOAD_DIR, upload_filename)filedata.save(img_path)start = time.time()# 打开图片img1 = Image.open(img_path)# 识别图片result_dict = html" title=ocr>ocr_img2text(img_path)# 识别时间end = time.time()recognize_time = int((end - start) * 1000)result_dict["filename"] = upload_filenameresult_dict["recognize_time"] = str(recognize_time)result_dict["error_code"] = "000000"result_dict["error_msg"] = "识别成功"return jsonify(result_dict)else:return render_template('upload.html')
    

5.PaddleOCR模型推理参数解释

  • 参数详情
    在这里插入图片描述

6.后续展望

  • 持续改进优化该部分代码,并完善文档。欢迎交流。。。
  • PaddleOCR模型推理参数解释
  • https://www.cnblogs.com/xh2023/p/17642994.html

http://www.ppmy.cn/ops/95102.html

相关文章

ARM/Linux嵌入式面经(二五):六方云科技

一面(技术面) (1)常规性自我介绍 (2)我看你项目做的嵌入式单片机的比较多,linux下的编程了解吗? 回答部分 “是的,我虽然在项目中更多地涉及了嵌入式单片机的开发,但我也对Linux下的编程有一定的了解和实践经验。在嵌入式系统中,Linux作为一个强大的操作系统平台…

代表性大数据技术:Hadoop、Spark与Flink的框架演进

MapReduce编程模型的提出为大数据分析和处理开创了一条先河&#xff0c;之后陆续涌现出了Hadoop、Spark和Flink等大数据框架。 Hadoop 2004年&#xff0c;Hadoop的创始人受MapReduce编程模型等一系列论文的启发&#xff0c;对论文中提及的思想进行了编程实现。Hadoop的名字来源…

pdf文件名字太长导致不能删除也不能修改文件名的解决方法

使用winner压缩&#xff0c;压缩时候选删除原来的文件 &#xff0c;在把压缩包删了就可以了

PostgreSQL版本策略

PostgreSQL 全球开发组计划每年发布一个包含新功能的主要版本&#xff08;major version&#xff09;。同时&#xff0c;对于每个主要版本&#xff0c;至少每 3 个月会发布一个次要版本&#xff08;minor release&#xff09;&#xff0c;用于修复问题和安全漏洞。 当前最新的…

OpenCV Python 图像处理入门

OpenCV入门 OpenCV&#xff1a;轻量、高效、开源。最广泛使用的计算机视觉工具。 下面涉及图片的读取&#xff0c;RGB彩色通道&#xff0c;区域裁剪&#xff0c;绘制图形和文字&#xff0c;均值滤波&#xff0c;特征提取&#xff0c;模板匹配&#xff0c;梯度算法&#xff0c…

[Qt][Qt窗口][上]详细讲解

目录 0.前言1.菜单栏0.是什么&#xff1f;1.创建菜单栏2.在菜单栏中添加菜单3.创建菜单项4.给菜单和菜单项设置快捷键5.在菜单项之间添加分割线6.给菜单和菜单项添加图标 0.前言 Qt窗⼝是通过QMainWindow类来实现的 QMainWindow是⼀个为⽤⼾提供主窗⼝程序的类&#xff0c;继承…

ARM/Linux嵌入式面经(二四):国光电器

一面(群面) (1)常规的自我介绍 一个既专业又能够吸引面试官注意力的自我介绍模板如下。但是请根据自己的实际经历和技能进行适当调整和补充: 尊敬的面试官,您好!我是[您的姓名],非常荣幸有机会参加这次嵌入式系统工程师的面试。我毕业于[毕业院校],主修[专业名称],在…

Spring 02: Bean概览

Spring Bean是什么&#xff1f; 在 Spring 中&#xff0c;Bean 是一个由 Spring IoC&#xff08;控制反转&#xff09;容器管理的对象。Bean 通常通过在 XML 配置文件、Java 配置类或基于注解的方式定义&#xff0c;并由容器负责创建和配置。Spring 容器负责管理 Bean 的整个生…