yolov5使用flask部署至前端,实现照片\视频识别
创始人
2025-01-16 17:34:27
0
大半年前初学yolo flask时,急需此功能,Csdn、Github、B站找到很多教程,效果并不是很满意。
近期做项目碰到类似需求,再度尝试,实现简单功能,分享下相关代码,仅学习使用,如有纰漏,望多包涵。

实现功能:

  1. 可更换权重文件(best.py)

  2. 上传图片并识别,可以点击图片放大查看

  3. 上传视频并识别

  4. 识别后的文件下载功能

效果图如上

文件结构如下:

project/
  static/

  空

  templates/
    index.html
    
 app.py
 

相关代码:

app.py

import cv2 import numpy as np import torch from flask import Flask, request, jsonify, render_template import base64 import os from datetime import datetime from werkzeug.utils import secure_filename app = Flask(__name__)  # 全局变量:模型和模型权重路径 model = None    # 提前加载模型 # 提前加载模型 def load_model():     global model     global new_filename     # 拼接权重文件的完整路径     model = torch.hub.load("E:\\pythonProject2\\flaskProject\\yolov5-master", "custom", path='weight/'+new_filename, source="local")   # 路由处理图片检测请求 @app.route("/predict_image", methods=["POST"]) def predict_image():     global model      # 获取图像文件     file = request.files["image"]     # 读取图像数据并转换为RGB格式     image_data = file.read()     nparr = np.frombuffer(image_data, np.uint8)     image = cv2.imdecode(nparr, cv2.IMREAD_UNCHANGED)      results = model(image)      image = results.render()[0]      # 将图像转换为 base64 编码的字符串     _, buffer = cv2.imencode(".png", image)     image_str = base64.b64encode(buffer).decode("utf-8")      # 获取当前时间,并将其格式化为字符串     current_time = datetime.now().strftime("%Y%m%d%H%M%S")     # 构建保存路径     save_dir = "static"     filename, extension = os.path.splitext(file.filename)  # 获取上传文件的文件名和扩展名     save_filename = f"{filename}_{current_time}{extension}"     save_path = os.path.join(save_dir, save_filename)     cv2.imwrite(save_path, image)      return jsonify({"image": image_str})   # 函数用于在视频帧上绘制检测结果 def detect_objects(frame, model):     results = model(frame)     detections = results.pred[0]  # 这里假设只有一张输入图片     # 在帧上绘制检测结果     for det in detections:         # 获取边界框信息         x1, y1, x2, y2, conf, class_id = det[:6]          # 在帧上绘制边界框         cv2.rectangle(frame, (int(x1), int(y1)), (int(x2), int(y2)), (0, 255, 0), 2)          # 在帧上绘制类别和置信度         label = f'{model.names[int(class_id)]} {conf:.2f}'         cv2.putText(frame, label, (int(x1), int(y1) - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 255, 0), 2)         print(f'Confidence: {conf:.2f}')     return frame   # 路由处理视频检测请求 @app.route("/predict_video", methods=["POST"]) def predict_video():     global model      # 从请求中获取视频文件     video_file = request.files["video"]     # 保存视频到临时文件     temp_video_path = "temp_video.mp4"     video_file.save(temp_video_path)      # 逐帧读取视频     video = cv2.VideoCapture(temp_video_path)      # 获取视频的帧率和尺寸     fps = video.get(cv2.CAP_PROP_FPS)     width = int(video.get(cv2.CAP_PROP_FRAME_WIDTH))     height = int(video.get(cv2.CAP_PROP_FRAME_HEIGHT))      # 视频写入对象     output_video_filename = f"output_video_{datetime.now().strftime('%Y%m%d%H%M%S')}.mp4"     output_video_path = os.path.join("static", output_video_filename)     fourcc = cv2.VideoWriter_fourcc(*"avc1")  # 使用 H.264 编码器     out_video = cv2.VideoWriter(output_video_path, fourcc, fps, (width, height))      # 逐帧处理视频并进行目标检测     while True:         ret, frame = video.read()         if not ret:             break          # 进行目标检测         detection_result = detect_objects(frame, model)          # 将处理后的帧写入输出视频         out_video.write(detection_result)      # 释放视频对象     video.release()     out_video.release()      return jsonify({"output_video_path": output_video_filename})  @app.route("/upload_weight", methods=["POST"]) def upload_weight():     global new_filename     # 获取上传的权重文件     weight_file = request.files["weight"]     # 获取上传文件的原始文件名     original_filename = secure_filename(weight_file.filename)     # 提取文件名和扩展名     filename, extension = os.path.splitext(original_filename)     # 构造新的文件名,加上当前时间戳     current_time = datetime.now().strftime("%Y%m%d%H%M%S")     new_filename = f"best_{current_time}.pt"     # 拼接权重文件的保存路径     save_path = os.path.join("E:\\pythonProject2\\flaskProject\\weight\\", new_filename)     # 保存权重文件     weight_file.save(save_path)     # 加载模型     load_model()      return jsonify({"message": "Weight file uploaded successfully and model loaded"}) @app.route("/") def index():      return render_template("index.html")  if __name__ == "__main__":     app.run(debug=True)  

index.html

                 Object Detection            

上传权重文件


×

照片/视频检测

上传图片



上传视频



使用说明:

将index.html放入templates文件夹中

运行app.py

model = torch.hub.load("E:\\pythonProject2\\flaskProject\\yolov5-master", "custom", path='weight/'+new_filename, source="local")

注意此处加载模型路径更改为自己的

如果模型读取不到,csdn上有相关解决方法

此处的best.py上传路径也要更改成自己的

save_path = os.path.join("E:\\pythonProject2\\flaskProject\\weight\\", new_filename)

使用说明:

先上传本地的模型,上传成功后等待模型加载,再上传照片/视频

如有问题,可联系作者,随时讨论。

相关内容

热门资讯

透视黑科技!wepoker钻石... 透视黑科技!wepoker钻石怎么看底牌(透视)从来有挂(详细辅助系统教程);1分钟了解详细教程(微...
透视脚本!wepoker免费永... 透视脚本!wepoker免费永久脚本(透视)详细辅助透明挂教程(一直真的有挂)1、在wepoker免...
透视科技!aapoker透视怎... 透视科技!aapoker透视怎么用,德普软件(详细辅助必胜教程)aapoker透视怎么用软件透明挂微...
透视规律(wePOKE)wep... 透视规律(wePOKE)wepower让系统发好牌(透视)详细辅助分享教程关于wepower让系统发...
透视最新!aapoker能控制... 1、透视最新!aapoker能控制牌吗(透视)原来有挂(详细辅助大神讲解);详细教程。2、aapok...
透视辅助!aapoker辅助是... 透视辅助!aapoker辅助是真的吗,werplan怎么透视(详细辅助介绍教程)1、下载好aapok...
透视实锤!wpk辅助器安装(透... 透视实锤!wpk辅助器安装(透视)详细辅助微扑克教程(一直有挂)1、全新机制【wpk辅助器安装软件透...
透视透视(WePoKer)wp... 透视透视(WePoKer)wpk发牌算法(透视)详细辅助介绍教程;支持2-10人实时对战,虚拟庄家发...
透视工具!拱趴大菠萝辅助神器(... 透视工具!拱趴大菠萝辅助神器(透视)果然真的有挂(详细辅助细节方法);支持2-10人实时对战,虚拟庄...
透视透视!智星德州菠萝插件官网... 透视透视!智星德州菠萝插件官网,智星德州插件2024最新版(详细辅助黑科技教程);1、实时智星德州菠...