2

我想在django中使用yolov5模型,但是遇到了麻烦。

我想做的是,如果用户将图像上传到 django 服务器,使用 yolov5 模型进行对象检测,然后将结果显示在网络上。这个过程本身很简单。 但我不确定如何附加 yolov5 api 和 django。

用过yolo的人都知道,yolo基本上是基于命令运行api的。

!python train.py --img 512 --batch 16 --epochs 100 --data ~~   # for training
!python detect.py --weights'/content/yolov5/runs/~~            # for detection

有没有办法在 Django 视图中运行它?

我尝试了诸如 execfile() 和 os.system() 之类的 Python 函数,它们在 Python 脚本中以解释器的方式执行命令,但它不能正常工作。(我认为 Django 和 Yolo 之间的路径是曲折的。)

事实上,如果可能的话,最好像 Keras 一样将 yolo api 加载为模块并像函数一样运行,而不是命令方法。但是我找不到像模块或类似的东西一样使用yolov5的方法。

我怎么解决这个问题?请给我一些建议。

4

1 回答 1

0

使用 Django 和 Yolov5 进行对象检测

我已经在 Github 上上传了Django-Yolov5 样板文件,方便参考。

模型.py:

import os

from django.db import models
from django.utils.translation import gettext_lazy as _


class ImageModel(models.Model):
    image = models.ImageField(_("image"), upload_to='images')

    class Meta:
        verbose_name = "Image"
        verbose_name_plural = "Images"

    def __str__(self):
        return str(os.path.split(self.image.path)[-1])

视图.py:

import io
from PIL import Image as im
import torch

from django.shortcuts import render
from django.views.generic.edit import CreateView

from .models import ImageModel
from .forms import ImageUploadForm


class UploadImage(CreateView):
    model = ImageModel
    template_name = 'image/imagemodel_form.html'
    fields = ["image"]

    def post(self, request, *args, **kwargs):
        form = ImageUploadForm(request.POST, request.FILES)
        if form.is_valid():
            img = request.FILES.get('image')
            img_instance = ImageModel(
                image=img
            )
            img_instance.save()

            uploaded_img_qs = ImageModel.objects.filter().last()
            img_bytes = uploaded_img_qs.image.read()
            img = im.open(io.BytesIO(img_bytes))

            # Change this to the correct path
            path_hubconfig = "absolute/path/to/yolov5_code"
            path_weightfile = "absolute/path/to/yolov5s.pt"  # or any custom trained model

            model = torch.hub.load(path_hubconfig, 'custom',
                               path=path_weightfile, source='local')

            results = model(img, size=640)
            results.render()
            for img in results.imgs:
                img_base64 = im.fromarray(img)
                img_base64.save("media/yolo_out/image0.jpg", format="JPEG")

            inference_img = "/media/yolo_out/image0.jpg"

            form = ImageUploadForm()
            context = {
                "form": form,
                "inference_img": inference_img
            }
            return render(request, 'image/imagemodel_form.html', context)

        else:
            form = ImageUploadForm()
        context = {
            "form": form
        }
        return render(request, 'image/imagemodel_form.html', context)

在这个views.py中可以修改很多,比如添加更多的功能和逻辑,但这里的目的是连接yolov5和Django。views.py 中的配置是最重要的,因为它是 yolov5 hubconf.py 文件的网关。

表格.py

from django import forms
from .models import ImageModel


class ImageUploadForm(forms.ModelForm):
    class Meta:
        model = ImageModel
        fields = ['image']

Imagemodel_form.html

{% extends "base.html" %}
{% load crispy_forms_tags %}


{% block leftbar %}
    <div class="col-sm-3">

    </div>
{% endblock leftbar %} 


{% block content %}
    <div class="col-sm-9">
        <div id="uploadedImage"></div>
            <div class="mt-4">
                <form action="" enctype="multipart/form-data" id="imageUploadForm" method="post"> 
                    {% csrf_token %}
                    {{ form|crispy }}
                    <button class="btn btn-outline-success" type="submit">Submit</button>
                </form>
            </div>
        </div>
        <div class="mt-4">
            {% if inference_img %}
                <img src="{{inference_img}}" class="img-fluid" />
            {% else %}
                The inferenced image will be displayed here.
            {% endif %}
        </div>    
    </div>
{% endblock content %}

最初的简单网页:

在此处输入图像描述

检测后:

在此处输入图像描述

于 2021-07-21T17:12:45.717 回答