在 Django 中将 numpy 数组显示为图像

TaQ*_*gTu 3 python django numpy

我是 Django 框架的新手。我正在构建一个网站,该网站从用户那里获取图像,然后处理图像并返回到 numpy 数组(处理后的图像)。我想将 numpy 数组显示为图像。我怎样才能做到这一点?感谢您的阅读并提供帮助?

索引.html

<form name="image" method = "post" enctype="multipart/form-data">
    {% csrf_token %}
    {{ form.as_p }}
    <button type="submit">Upload</button>
</form>
Run Code Online (Sandbox Code Playgroud)

索引视图

def index(request):
    if request.method == 'POST':
        form = UploadFileForm(request.POST, request.FILES)
        if form.is_valid():
            model = MyDeepLearningModel.get_instance()
            file_name = request.FILES['file']

            processed_image = model.run_png(file_name) #processed_image is an numpy array

            #how to show the processed_image in index.html?
            return render(request, 'lowlighten/index.html')
    else:
        form = UploadFileForm()
    return render(request, 'lowlighten/index.html', {'form': form})
Run Code Online (Sandbox Code Playgroud)

kar*_*mad 7

好吧,让我们首先就某件事达成一致:要在前端显示图像,您需要有该图像的 url,该图像应该存在于已知的位置,以便前端可以从中加载它。

所以我假设您不愿意将此图像保存在任何地方(例如 imgur 或其他地方),因此最好的办法是从该图像中创建一个数据 uri。

首先我们需要将 numpy 数组转换为图像:

from PIL import Image 

def to_image(numpy_img):
    img = Image.fromarray(data, 'RGB')
    return img

Run Code Online (Sandbox Code Playgroud)

然后,为了从该图像中获取 uri,我们需要进一步处理它:

import base64
from io import BytesIO
def to_data_uri(pil_img):
    data = BytesIO()
    img.save(data, "JPEG") # pick your format
    data64 = base64.b64encode(data.getvalue())
    return u'data:img/jpeg;base64,'+data64.decode('utf-8') 
Run Code Online (Sandbox Code Playgroud)

现在您已将图像编码为数据 URI,您可以将该数据 URI 传递到前端并在 img 标签中使用它

<img src={{ image_uri }} />
Run Code Online (Sandbox Code Playgroud)

在此基础上,我们可以按如下方式更改您的功能:

def index(request):
    if request.method == 'POST':
        form = UploadFileForm(request.POST, request.FILES)
        if form.is_valid():
            model = MyDeepLearningModel.get_instance()
            file_name = request.FILES['file']

            processed_image = model.run_png(file_name) #processed_image is an numpy array
            pil_image = to_image(processed_image)
            image_uri = to_data_uri(pil_image)

            #how to show the processed_image in index.html?
            return render(request, 'lowlighten/index.html', {'image_uri': image_uri})
    else:
        form = UploadFileForm()
    return render(request, 'lowlighten/index.html', {'form': form})
Run Code Online (Sandbox Code Playgroud)