python+tifffile之tiff文件讀寫(xiě)方式
背景
使用python操作一批同樣分辨率的圖片,合并為tiff格式的文件。
由于opencv主要用于讀取單幀的tiff文件,對(duì)多幀的文件支持并不好。
通過(guò)搜索發(fā)現(xiàn)了兩個(gè)比較有用的包:TiffCapture和tifffile。兩者都可用pip安裝。
其中前者主要用于讀取tiff文件,后者可讀可寫(xiě)。最終選擇tifffile來(lái)合成tiff圖片文件。
安裝tifffile
pip install tifffile
原理及代碼
我的圖片是8 bit灰度圖。
每次讀取之后,先升維:
new_gray = gray_img[np.newaxis, ::]
然后再使用np.append添加到數(shù)組里。每append一次,相當(dāng)于tiff增加一幀圖片。
tiff_list = np.append(tiff_list, new_gray, axis=0)
所有操作完畢,則一次性保存到磁盤(pán)。
tifffile.imsave( out_tiff_path, tiff_list )
下面是我的完整代碼:
import cv2
import tifffile
import time
import numpy as np
import time
import os
img_path = '../word_all'
out_txt_path = '../out_word_all.box'
out_tiff_path = '../out_word_all.tif'
tiff_list = None
with open(out_txt_path, 'wb') as f:
dir_list = os.listdir(img_path)
cnt_num = 0
for dir_name in dir_list:
dir_path = os.path.join(img_path, dir_name)
img_list = os.listdir(dir_path)
pwd = os.getcwd()
os.chdir(dir_path)
for img in img_list:
print('dir_path:{}'.format(dir_path))
gray_img = cv2.imread(img, cv2.IMREAD_GRAYSCALE)
new_gray = gray_img[np.newaxis, ::]
print('gray_img shape:{}, new_gray shape:{}'.format(gray_img.shape, new_gray.shape))
#global cnt_num
if cnt_num == 0:
print('cnt_num == 0')
tiff_list = new_gray
else:
print('np.append')
tiff_list = np.append(tiff_list, new_gray, axis=0)
print('tiff_list shape:{}'.format(tiff_list.shape))
content = '{} 2 2 60 60 {}\n'.format(dir_name, cnt_num)
print(content)
f.write(content.encode('UTF-8'))
cnt_num += 1
os.chdir(pwd)
tifffile.imsave( out_tiff_path, tiff_list )
print('tiff_list shape:{}'.format(tiff_list.shape))
以上這篇python+tifffile之tiff文件讀寫(xiě)方式就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
使用python實(shí)現(xiàn)個(gè)性化詞云的方法
最近看到可視化的詞云,看到網(wǎng)上也很多這樣的工具,但是都不怎么完美,有些不支持中文,有的中文詞頻統(tǒng)計(jì)得莫名其妙、有的不支持自定義形狀、所有的都不能自定義顏色,于是網(wǎng)上找了一下,決定用python繪制詞云2017-06-06
Django正則URL匹配實(shí)現(xiàn)流程解析
這篇文章主要介紹了Django正則URL匹配實(shí)現(xiàn)流程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11
OpenCV+Python--RGB轉(zhuǎn)HSI的實(shí)現(xiàn)
今天小編就為大家分享一篇OpenCV+Python--RGB轉(zhuǎn)HSI的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11
python實(shí)現(xiàn)自動(dòng)發(fā)送報(bào)警監(jiān)控郵件
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)自動(dòng)發(fā)送報(bào)警監(jiān)控郵件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-06-06
Python 中如何使用 virtualenv 管理虛擬環(huán)境
這篇文章主要介紹了Python 中使用 virtualenv 管理虛擬環(huán)境的方法,幫助大家更好的理解和使用python,感興趣的朋友可以了解下2021-01-01
python網(wǎng)絡(luò)爬蟲(chóng)之模擬登錄 自動(dòng)獲取cookie值 驗(yàn)證碼識(shí)別的具體實(shí)現(xiàn)
有時(shí),我們需要爬取一些基于個(gè)人用戶的用戶信息(需要登陸后才可以查看)就要進(jìn)行模擬登陸,因?yàn)轵?yàn)證碼往往是作為登陸請(qǐng)求中的請(qǐng)求參數(shù)被使用,就需要識(shí)別驗(yàn)證碼2021-09-09
python K近鄰算法的kd樹(shù)實(shí)現(xiàn)
這篇文章主要介紹了python K近鄰算法的kd樹(shù)實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09

