python存储16bit和32bit图像的实例


Posted in Python onDecember 05, 2018

笔记:python中存储16bit和32bit图像的方法。

说明:主要是利用scipy库和pillow库,比较其中的不同。

'''
测试16bit和32bit图像的python存储方法
'''
import numpy as np
 
import scipy.misc
from PIL import Image
 
# 用已有的8bit和16bit图作存储测试
path16 = 'D:\Py_exercise\lena16.tif'
path8 = 'D:\Py_exercise\lena8.tif'
tif16 = scipy.misc.imread(path16)  #<class 'numpy.uint16'>
tif8 = scipy.misc.imread(path8)   #<class 'numpy.uint8'>
print(np.shape(tif16),type(tif16[0,0])) 
print(np.shape(tif8),type(tif8[0,0])) 
print()
 
save16 = 'D:\Py_exercise\lena16_save.tif'
save8 = 'D:\Py_exercise\lena8_save.tif'
scipy.misc.imsave(save16, tif16)   #--> 8bit
scipy.misc.imsave(save8, tif8)   #--> 8bit
 
 
# Create a mat which is 64 bit float
nrows = 512
ncols = 512
np.random.seed(12345)
y = np.random.randn(nrows, ncols)*65535 #<class 'numpy.float64'>
print(type(y[0,0]))
print()
 
# Convert y to 16 bit unsigned integers
z16 = (y.astype(np.uint16))    #<class 'numpy.uint16'>
print(type(z16[0,0]))
print()
 
# 用产生的随机矩阵作存储测试
save16 = 'D:\Py_exercise\lena16_save1.tif'
scipy.misc.imsave(save16, z16)     #--> 8bit
 
im = Image.frombytes('I;16', (ncols,nrows), y.tostring())
im.save('D:\Py_exercise\lena16_save21.tif') #--> 16bit
im = Image.fromarray(y)      
im.save('D:\Py_exercise\lena16_save22.tif') #--> 32bit
im = Image.fromarray(z16)      
im.save('D:\Py_exercise\lena16_save23.tif') #--> 16bit
 
# 归一化后的np.float64仍然存成了uint8
zNorm = (z16-np.min(z16))/(np.max(z16)-np.min(z16)) #<class 'numpy.float64'>
print(type(zNorm[0,0]))
save16 = 'D:\Py_exercise\lena16_save11.tif'
scipy.misc.imsave(save16, zNorm)    #--> 8bit
 
# 归一化后的np.float64直接转8bit或16bit都会超出阈值,要*255或*65535
# 如果没有astype的位数设置,会直接存成32bit
zImg = (zNorm*65535).astype(np.uint16) 
im = Image.fromarray(zImg)
im.save('D:\Py_exercise\lena16_save31.tif') #--> 16bit
im = Image.fromarray(zNorm)
im.save('D:\Py_exercise\lena16_save32.tif') #--> 32bit(0~1)

以上这篇python存储16bit和32bit图像的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
详解在Python程序中自定义异常的方法
Oct 16 Python
Python语言实现获取主机名根据端口杀死进程
Mar 31 Python
Python基于xlrd模块操作Excel的方法示例
Jun 21 Python
python list转矩阵的实例讲解
Aug 04 Python
python+opencv实现霍夫变换检测直线
Oct 23 Python
python实现字符串加密成纯数字
Mar 19 Python
python f-string式格式化听语音流程讲解
Jun 18 Python
python正则爬取某段子网站前20页段子(request库)过程解析
Aug 10 Python
django的autoreload机制实现
Jun 03 Python
Python faker生成器生成虚拟数据代码实例
Jul 20 Python
python向xls写入数据(包括合并,边框,对齐,列宽)
Feb 02 Python
教你怎么用Python生成九宫格照片
May 20 Python
Python随机生成身份证号码及校验功能
Dec 04 #Python
python 从文件夹抽取图片另存的方法
Dec 04 #Python
使用Python实现微信提醒备忘录功能
Dec 04 #Python
flask-restful使用总结
Dec 04 #Python
Python读取YUV文件,并显示的方法
Dec 04 #Python
对Python3+gdal 读取tiff格式数据的实例讲解
Dec 04 #Python
用python代码将tiff图片存储到jpg的方法
Dec 04 #Python
You might like
PHP实现的Redis多库选择功能单例类
2017/07/27 PHP
JS无限极树形菜单,json格式、数组格式通用示例
2013/07/30 Javascript
Jquery绑定事件(bind和live的区别介绍)
2013/08/23 Javascript
JavaScript中判断整数的多种方法总结
2014/11/08 Javascript
jQuery不使用插件及swf实现无刷新文件上传
2014/12/08 Javascript
JavaScript获取网页表单action属性的方法
2015/04/02 Javascript
js 求时间差的实现代码
2016/04/26 Javascript
jquery中live()方法和bind()方法区别分析
2016/06/23 Javascript
AngularJS基础 ng-paste 指令简单示例
2016/08/02 Javascript
Bootstrap实现input控件失去焦点时验证
2016/08/04 Javascript
JS实现表单验证功能(验证手机号是否存在,验证码倒计时)
2016/10/11 Javascript
完美解决jQuery fancybox ie 无法显示关闭按钮的问题
2016/11/29 Javascript
easyui combotree加载静态数据问题(选不上)解决方法
2016/12/26 Javascript
Bootstrap Scrollspy源码学习
2017/03/02 Javascript
谈谈vue中mixin的一点理解
2017/12/12 Javascript
详解Angular2学习笔记之Html属性绑定
2018/01/03 Javascript
详解自定义ajax支持跨域组件封装
2018/02/08 Javascript
老生常谈JS中的继承及实现代码
2018/07/06 Javascript
JS页面获取 session 值,作用域和闭包学习笔记
2019/10/16 Javascript
JS前后端实现身份证号验证代码解析
2020/07/23 Javascript
vue-cli3自动消除console.log()的调试信息方式
2020/10/21 Javascript
[01:05:59]Mineski vs Secret 2019国际邀请赛淘汰赛 败者组 BO3 第二场 8.22
2019/09/05 DOTA
python 获取本机ip地址的两个方法
2013/02/25 Python
Python3实现连接SQLite数据库的方法
2014/08/23 Python
浅谈python中截取字符函数strip,lstrip,rstrip
2015/07/17 Python
python pandas 如何替换某列的一个值
2018/06/09 Python
python使用KNN算法识别手写数字
2019/04/25 Python
解决Python3.8用pip安装turtle-0.0.2出现错误问题
2020/02/11 Python
html5 viewport使用方法示例详解
2013/12/02 HTML / CSS
学生手册家长评语
2014/02/10 职场文书
团拜会策划方案
2014/06/07 职场文书
淘宝客服工作职责
2014/07/11 职场文书
反四风对照检查材料
2014/09/22 职场文书
践行三严三实心得体会
2014/10/13 职场文书
退休教师追悼词
2015/06/23 职场文书
Python 装饰器(decorator)常用的创建方式及解析
2022/04/24 Python