使用OpenCv python库从内存中读取基本的64位编码图像 [英] Read a base 64 encoded image from memory using OpenCv python library

查看:774
本文介绍了使用OpenCv python库从内存中读取基本的64位编码图像的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在开发一个应用程序,该应用程序可以从网络摄像头流中进行一些面部识别.我得到画布的base64编码的数据uri,并希望使用它来执行以下操作:

I'm working on an app that to do some facial recognition from a webcam stream. I get base64 encoded data uri's of the canvas and want to use it to do something like this:

cv2.imshow('image',img)

数据URI看起来像这样:

The data URI looks something like this:

 

因此,为清楚起见,我已经显示了图像的外观,因此base64字符串没有损坏.

So, for clarity I've shown what the image looks like so the base64 string is not broken.

<img src="">

官方文档表示,接受文件路径作为参数.从 SO答案,如果我这样做:

The official doc says, that imread accepts a file path as the argument. From this SO answer, if I do something like:

 import base64
 imgdata = base64.b64decode(imgstring) #I use imgdata as this variable itself in references below
 filename = 'some_image.jpg'
 with open(filename, 'wb') as f:
    f.write(imgdata)

以上代码段有效,并且图像文件已正确生成.但是考虑到我将对流的每个帧执行此操作,因此我认为没有太多文件IO操作是可行的.我希望能够直接将图像读取到内存中,从而创建img对象.

The above code snippet works and the image file gets generated properly. However I don't think so many File IO operations are feasible considering I'd be doing this for every frame of the stream. I want to be able to read the image into the memory directly creating the img object.

我尝试了两种似乎对某些人有用的解决方案.

I have tried two solutions that seem to be working for some people.

  1. 使用PIL 参考:

pilImage = Image.open(StringIO(imgdata))
npImage = np.array(pilImage)
matImage = cv.fromarray(npImage)

我得到的cv没有定义,因为我安装了openCV3,可以作为cv2模块使用.我尝试了img = cv2.imdecode(npImage,0),它什么也没返回.

I get cv not defined as I have openCV3 installed which is available to me as cv2 module. I tried img = cv2.imdecode(npImage,0), this returns nothing.

从解码后的字符串中获取字节并将其转换为numpy的数组

Getting the bytes from decoded string and converting it into an numpy array of sorts

file_bytes = numpy.asarray(bytearray(imgdata), dtype=numpy.uint8)
img = cv2.imdecode(file_bytes, 0) #Here as well I get returned nothing

文档没有真正提及imdecode函数返回的内容.但是,从我遇到的错误中,我猜它期望将numpy arrayscalar作为第一个参数.如何在内存中获取该图像的句柄,以便以后可以执行cv2.imshow('image',img)和各种有趣的操作.

The documentation doesn't really mention what the imdecode function returns. However, from the errors that I encountered, I guess it is expecting a numpy array or a scalar as the first argument. How do I get a handle on that image in memory so that I can do cv2.imshow('image',img) and all kinds of cool stuff thereafter.

我希望我能说清楚自己.

I hope I was able to make myself clear.

推荐答案

您可以像这样同时使用cv2和枕头:

You can just use both cv2 and pillow like this:

import base64
from PIL import Image
import cv2
from StringIO import StringIO
import numpy as np

def readb64(base64_string):
    sbuf = StringIO()
    sbuf.write(base64.b64decode(base64_string))
    pimg = Image.open(sbuf)
    return cv2.cvtColor(np.array(pimg), cv2.COLOR_RGB2BGR)

cvimg = readb64('R0lGODlhEAAQAMQAAORHHOVSKudfOulrSOp3WOyDZu6QdvCchPGolfO0o/XBs/fNwfjZ0frl3/zy7////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAkAABAALAAAAAAQABAAAAVVICSOZGlCQAosJ6mu7fiyZeKqNKToQGDsM8hBADgUXoGAiqhSvp5QAnQKGIgUhwFUYLCVDFCrKUE1lBavAViFIDlTImbKC5Gm2hB0SlBCBMQiB0UjIQA7')
cv2.imshow(cvimg)

这篇关于使用OpenCv python库从内存中读取基本的64位编码图像的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆