您的位置:首页 > 电脑安全 > 黑客漏洞 > Python实现图像的二进制与base64互转

Python实现图像的二进制与base64互转

2022-03-30 15:45:39 来源:易采站长站 作者:

Python实现图像的二进制与base64互转

目录
函数使用1.图像转base64编码2.图像转二进制编码3.图像保存成二进制文件并读取二进制4.二进制转图像5.base64转图像6.互转7.二进制转base648.base64转二进制

函数使用

def base64_to_image(base64_code):
    img_data = base64.b64decode(base64_code)
    img_array = numpy.fromstring(img_data, numpy.uint8)
    # img_array = np.frombuffer(image_bytes, dtype=np.uint8) #可选
    image_base64_dec = cv2.imdecode(img_array, cv2.COLOR_RGB2BGR)
    return image_base64_dec
 
def image_to_base64(full_path):
    with open(full_path, "rb") as f:
        data = f.read()
        image_base64_enc = base64.b64encode(data)
        image_base64_enc = str(image_base64_enc, 'utf-8')
    return image_base64_enc
#传base64    
img_bytes = request.json["img_stream"]
img_cv = base64_to_image(img_bytes)
uuid_str = str(uuid.uuid1())
img_path = uuid_str +".jpg"
cv2.imwrite(img_path,img_cv)

1.图像转base64编码

import cv2
import base64
 
def cv2_base64(image):
    img = cv2.imread(image)
    binary_str = cv2.imencode('.jpg', img)[1].tostring()#编码
    base64_str = base64.b64encode(binary_str)#解码
    base64_str = base64_str.decode('utf-8')
    myjson={"bs64":cv2_base64("1.jpg")}
    print(myjson)
    return base64_str

2.图像转二进制编码

import cv2
import base64
 
def cv2_binary(image):
    img = cv2.imread(image)
    binary_str = cv2.imencode('.jpg', img)[1].tostring()#编码
    print(binary_str)
    # base64_str = base64.b64encode(binary_str)#解码
    # base64_str = base64_str.decode('utf-8')
    # print(base64_str)
    return binary_str
 
cv2_binary("1.jpg")
# 或者
image_file =r"1.jpg"
image_bytes = open(image_file, "rb").read()
print(image_bytes)# 二进制数据

3.图像保存成二进制文件并读取二进制

#   python+OpenCV读取图像并转换为二进制格式文件的代码
 
# coding=utf-8
'''
Created on 2016年3月24日
使用Opencv读取图像将其保存为二进制格式文件,再读取该二进制文件,转换为图像进行显示
@author: hanchao
'''
import cv2
import numpy as np
import struct
 
image = cv2.imread("1.jpg")
# imageClone = np.zeros((image.shape[0],image.shape[1],1),np.uint8)
 
# image.shape[0]为rows
# image.shape[1]为cols
# image.shape[2]为channels
# image.shape = (480,640,3)
rows = image.shape[0]
cols = image.shape[1]
channels = image.shape[2]
# 把图像转换为二进制文件
# python写二进制文件,f = open('name','wb')
# 只有wb才是写二进制文件
fileSave = open('patch.bin', 'wb')
for step in range(0, rows):
    for step2 in range(0, cols):
        fileSave.write(image[step, step2, 2])
for step in range(0, rows):
    for step2 in range(0, cols):
        fileSave.write(image[step, step2, 1])
for step in range(0, rows):
    for step2 in range(0, cols):
        fileSave.write(image[step, step2, 0])
fileSave.close()
 
# 把二进制转换为图像并显示
# python读取二进制文件,用rb
# f.read(n)中n是需要读取的字节数,读取后需要进行解码,使用struct.unpack("B",fileReader.read(1))函数
# 其中“B”为无符号整数,占一个字节,“b”为有符号整数,占1个字节
# “c”为char类型,占一个字节
# “i”为int类型,占四个字节,I为有符号整形,占4个字节
# “h”、“H”为short类型,占四个字节,分别对应有符号、无符号
# “l”、“L”为long类型,占四个字节,分别对应有符号、无符号
fileReader = open('patch.bin', 'rb')
imageRead = np.zeros(image.shape, np.uint8)
for step in range(0, rows):
    for step2 in range(0, cols):
        a = struct.unpack("B", fileReader.read(1))
        imageRead[step, step2, 2] = a[0]
for step in range(0, rows):
    for step2 in range(0, cols):
        a = struct.unpack("b", fileReader.read(1))
        imageRead[step, step2, 1] = a[0]
for step in range(0, rows):
    for step2 in range(0, cols):
        a = struct.unpack("b", fileReader.read(1))
        imageRead[step, step2, 0] = a[0]
 
fileReader.close()
cv2.imshow("source", image)
cv2.imshow("read", imageRead)
cv2.imwrite("2.jpg",imageRead)
cv2.waitKey(0)

4.二进制转图像

def binary_cv2(bytes):
    file = open("4.jpg","wb")
    file.write(bytes)
 
binary_cv2("bytes")
#或者
from PIL import Image
import io
img = Image.open(io.BytesIO("bytes"))
img.save("5.jpg")

5.base64转图像

def base64_cv2(base64code):
    img_data = base64.b64decode(base64code)
    file = open("2.jpg","wb")
    file.write(img_data)
    file.close()
 
base64_cv2("base64code")
============================================
with open("1.txt","r") as f:
    img_data = base64.b64decode(f.read())
    file = open("3.jpg","wb")
    file.write(img_data)
    file.close()

6.互转

def base64_to_image(base64_code):
    img_data = base64.b64decode(base64_code)
    img_array = numpy.fromstring(img_data, numpy.uint8)
    image_base64_dec = cv2.imdecode(img_array, cv2.COLOR_RGB2BGR)
    return image_base64_dec #图像矩阵,需要cv2.imwrite写入cv2.imwrite("1.jpg",img)
 
def image_to_base64(full_path):
    with open(full_path, "rb") as f:
        data = f.read()
        image_base64_enc = base64.b64encode(data)
        image_base64_enc = str(image_base64_enc, 'utf-8')
    return image_base64_enc

7.二进制转base64

def binary_base64(binary):
    img_stream = base64.b64encode(binary)
    bs64 = img_stream.decode('utf-8')
    print(bs64)

8.base64转二进制

import base64
 
bs64 = ""
img_data = base64.b64decode(bs64)
print(img_data)

以上就是Python实现图像的二进制与base64互转的详细内容,更多关于Python图像二进制转base64的资料请关注易采站长站其它相关文章!

如有侵权,请联系QQ:279390809 电话:15144810328

相关文章

  • 拯救者y9000x对比y7000p哪个更值得买

    拯救者y9000x对比y7000p哪个更值得买

    大家都知道,11月30日晚上,联想在其直播晚会上面发布了两款全新的电竞笔记本电脑,其中一款就是拯救者y9000x,随着新鲜血液的加入,让用户开心的同时也不知道该如何挑选适合自己的笔记本,今天小编就为大家带来拯救者y9000x和y7000p对比,感兴趣的朋友不要错过了。1、拯救者y9000x和y7000p参数对比2、拯救者y9000x和y7000p哪个好?Y7000p因为其电竞屏的配置,是一款典型的
    2020-12-03
  • 骁龙870对比骁龙865plus哪个好

    骁龙870对比骁龙865plus哪个好

    大家都知道,骁龙870 5G移动平台已经正式发布了,骁龙870更像是对骁龙865的一次终极优化升级,那么骁龙870性能究竟怎么样?骁龙870和骁龙865plus相比哪个性能更好?小编为大家带来关于骁龙870和骁龙865plus的详细对比,感兴趣的朋友不要错过了。1、主要参数对比2、CPU骁龙870采用了“1+3+4”八核架构,一个A77超大核最高频率可达3.2GHz。骁龙8
    2021-01-20
  • 如何判断显卡性能高低 显卡性能主要看哪些参数

    如何判断显卡性能高低 显卡性能主要看哪些参数

      很多小伙伴想要自己配置一台电脑,到挑选显卡的时候,不知道通过哪些显卡参数来判断一块显卡的性能好坏。为此,小编特意整理了本篇教程,帮助大家了解我们主要通过看显卡的哪几个参数,来得知显卡的性能强弱。如何判断显卡性能高低?显卡性能主要看哪些参数?  第一,流处理器,这个数量越多越好,数量多它的出图速度就越快,这个在显卡参数里面,有的标为流处理器数量,有的是标为CUDA核心数量。  第二,显卡核心频率
    2021-03-23
  • 显卡1060和1050ti怎么选 显卡1060和1050ti区别对比

    显卡1060和1050ti怎么选 显卡1060和1050ti区别对比

      显卡是电脑的重要组成部分之一,因此显卡的选择是非常重要的。有些朋友喜欢装gtx1060,而有些朋友就会喜欢装gtx1050ti。这两个显卡有什么区别呢?下面小编就给大家讲讲显卡1060和1050ti的区别有哪些。  显卡1060和1050ti区别对比:  为了比较直观的了解gtx1060与gtx1050ti显卡的区别,以图片的形式罗列出两者的参数。  1、GTX1060的性能比GTX1050T
    2021-03-24
  • 前端从浏览器的渲染到性能优化

    前端从浏览器的渲染到性能优化

    问题前瞻1. 为什么css需要放在头部?2. js为什么要放在body后面?3. 图片的加载和渲染会阻塞页面DOM构建吗?4. dom解析完才出现页面吗?5. 首屏时间根据什么来判定?浏览器渲染1.浏览器渲染图解浏览器渲染页面主要经历了下面的步骤:1.处理 HTML 标记并构建 DOM 树。2.处理 CSS 标记并构建 CSSOM 树。3.将 DOM 与 CSSOM 合并成一个渲染树。4.根据渲染
    2021-05-17
  • 详解Spring工厂特性

    详解Spring工厂特性

    一、饿汉式创建优势工厂创建之后,会将Spring配置文件中的所有对象都创建完成(饿汉式)。提高程序运行效率。避免多次IO,减少对象创建时间。(概念接近连接池,一次性创建好,使用时直接获取)二、生命周期方法 自定义初始化方法:添加“init-method”属性,Spring则会在创建对象之后,调用此方法。 自定义销毁方法:添加“destroy-method”属性,Spring则会在销毁对
    2021-05-19
  • Python基础之元组与文件知识总结

    Python基础之元组与文件知识总结

    大纲Python文件类型及汇总一、元组1 特征1.任意对象的有序集合2.通过下标访问3.不可变4.长度固定,任意类型,任意嵌套>>> t = (1,2,3,4,5)>>> t[0] = 2Traceback (most recent call last): File "", line 1, in TypeError: 'tuple' object does not
    2021-05-19
  • 华为MateView GT值得入手吗 华为MateView GT详细评测

    华为MateView GT值得入手吗 华为MateView GT详细评测

    5月19日华为召开新品发布会,正式进军显示器领域,并带来华为MateView和华为MateView GT两款产品,一款直面,一款曲面。华为此时进入显示器领域和当前消费者对于显示要求以及多屏办公娱乐的需求分不开,尤其是在越来也注重效率的当下,显示器早已不再是台式机的专属,很多笔记本用户也会在本身屏幕之外选择一款显示器作为第二块屏幕,从而实现更高效的办公、学习和娱乐。华为MateView GT详细评测
    2021-05-20