需求说明: 我想使用 opencv 的压缩图片功能,并且压缩完成后转为 base64 的编码返回给前台
我的目前的代码是这样的:
import cv2
import base64
img = cv2.imread("d:/aaa/1.jpg") #获取图片
cv2.imwrite("d:/aaa/2.jpg",img,[cv2.IMWRITE_JPEG_QUALITY,40]) #压缩图片
b64 = base64.b64encode(???) #我如何拿到上面这行已经压缩好的图片,而不是将其输出到文件?
但 opencv 似乎压缩完成之后就输出到文件了(其他的图片处理库比如 PIL 似乎也是这样,没法压图作为最后输出的一个可选功能),没法将处理过的数据其留存在变量里面,只能输出,查阅了相关资料也没什么收获。
这导致如果我一定要实现这个功能的话,现有的方法必须先将压过的图片存入到临时文件,然后再读取出来转为 base64,代码写的狼狈不说,io 方面的损耗也是大,而且产生临时文件,是不是有什么好更好的方法?
刚学 python 不久,卡住这个问题很久了,希望有人能够指点一下,谢谢。