欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python?opencv的imread方法無法讀取圖片問題

 更新時(shí)間:2023年08月22日 16:51:38   作者:ZXF-BW  
這篇文章主要介紹了python?opencv的imread方法無法讀取圖片問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

python opencv的imread方法無法讀取圖片

讀取的路徑、文件名只能帶有英文數(shù)字及一些特定字符,不能帶有中文、日文等字符?。?!

利用cv2.imread()讀取文件夾中的四個(gè)圖片文件:

在這里插入圖片描述

在這里插入圖片描述

讀取’error副本.png’圖片(文件名帶有中文),結(jié)果為None,未能讀??;

讀取‘新建文件夾/error.png’圖片(路徑中帶中文),結(jié)果為None,未能讀?。?/p>

讀取‘トニカクカワイイ.png’圖片(文件名帶日文),結(jié)果為None,未能讀?。?/p>

而文件名改為英文時(shí)得到’numpy.ndarray’類型,說明成功讀取。

再看展示圖片操作:

在這里插入圖片描述

用cv2.imshow(‘錯(cuò)誤’, d)顯示圖片時(shí),將標(biāo)題設(shè)為’錯(cuò)誤‘,但彈窗標(biāo)題顯示為亂碼,說明是編碼錯(cuò)誤。

總結(jié)原因:

是字符編碼的問題,導(dǎo)致cv2.imread未能找到對(duì)應(yīng)圖片文件。

目前找到的解決方法是修改路徑和文件名為英文數(shù)字及部分特定字符。

python opencv imread()中文路徑返回為空None的解決(imdecode函數(shù)的使用)

本質(zhì)原因并非網(wǎng)上某些地方說的是中文編碼UNICODE、UTF-8之類的問題,其實(shí)是python版opencv不接受NON-ASCII的中文路徑,為了使用中文路徑,可以借助一些其他的庫。

首先介紹一種通過numpy庫(畢竟這個(gè)是python中幾乎最常用庫之一了)的方法。

借助Numpy庫

讀取圖像時(shí),借助numpy庫的fromfile函數(shù)先把圖像文件以數(shù)據(jù)的方式讀入內(nèi)存,然后在內(nèi)存緩沖區(qū)內(nèi)用opencv提供的imdecode函數(shù)將該數(shù)據(jù)解碼成圖像數(shù)據(jù),

核心代碼如下:

path = r"D:\Learn4Python\中文路徑\中文文件名.jpg"
dat = np.fromfile(path,dtype=np.uint8)
img = cv2.imdecode(dat,cv2.IMREAD_UNCHANGED)

寫入(保存)圖像時(shí),用opencv提供的imencode函數(shù)將圖像數(shù)據(jù)編碼成numpy的數(shù)據(jù),然后借助numpy的tofile函數(shù)把數(shù)據(jù)寫入到路徑文件,

核心代碼如下:

path_zh_write = r"D:\Learn4Python\中文路徑\中文文件名寫入圖像.jpg"
out = cv2.imencode(".jpg",img)
out[1].tofile(path_zh_write)

為了方便學(xué)習(xí)和完整理解,寫了一段實(shí)驗(yàn)代碼供大家參考

完整代碼如下

import cv2
import numpy as np
#試驗(yàn)四種情況:路徑無中文、僅文件名中文、目錄和文件名均有中文、僅目錄有中文
path1 = r"D:\Learn4Python\EnglishFileName.jpg"
path2 = r"D:\Learn4Python\中文文件名.jpg"
path3 = r"D:\Learn4Python\中文路徑\中文文件名.jpg"
path4 = r"D:\Learn4Python\中文路徑\EnglishFileName.jpg"
path_zh_write = r"D:\Learn4Python\中文路徑\中文文件名寫入圖像.jpg"
path_en_write = r"D:\Learn4Python\EnglishFileName_writeImg.jpg"
img1 = cv2.imread(r"D:\Learn4Python\EnglishFileName.jpg")
img2 = cv2.imread(r"D:\Learn4Python\中文文件名.jpg")
img3 = cv2.imread(r"D:\Learn4Python\中文路徑\中文文件名.jpg")
img4 = cv2.imread(r"D:\Learn4Python\中文路徑\EnglishFileName.jpg")
#檢查讀取情況,結(jié)果只有路徑無中文的情況讀取成功
if img1 is None:
? ? print("img1 imread failed.")
else:
? ? print("img1 imread ok:",img1.shape)
if img2 is None:
? ? print("img2 imread failed.")
else:
? ? print("img2 imread ok:",img2.shape)
if img3 is None:
? ? print("img3 imread failed.")
else:
? ? print("img3 imread ok:",img3.shape)
if img4 is None:
? ? print("img4 imread failed.")
else:
? ? print("img4 imread ok:",img4.shape)
#借助numpy讀取圖像
dat1 = np.fromfile(path1,dtype=np.uint8)
img_d1 = cv2.imdecode(dat1,cv2.IMREAD_UNCHANGED)
dat2 = np.fromfile(path2,dtype=np.uint8)
img_d2 = cv2.imdecode(dat2,cv2.IMREAD_UNCHANGED)
dat3 = np.fromfile(path3,dtype=np.uint8)
img_d3 = cv2.imdecode(dat3,cv2.IMREAD_UNCHANGED)
dat4 = np.fromfile(path4,dtype=np.uint8)
img_d4 = cv2.imdecode(dat4,cv2.IMREAD_UNCHANGED)
#結(jié)果全部讀取成功
if img_d1 is None:
? ? print("img_d1 imdecode failed.")
else:
? ? print("img_d1 imdecode ok:",img_d1.shape)
if img_d2 is None:
? ? print("img_d2 imdecode failed.")
else:
? ? print("img_d2 imdecode ok:",img_d2.shape)
if img_d3 is None:
? ? print("img_d3 imdecode failed.")
else:
? ? print("img_d3 imdecode ok:",img_d3.shape)
if img_d4 is None:
? ? print("img_d4 imdecode failed.")
else:
? ? print("img_d4 imdecode ok:",img_d4.shape)
#嘗試用imwrite將圖像寫入文件,
#結(jié)果:無中文的路徑寫入成功,含中文的路徑寫入失敗
if cv2.imwrite(path_en_write,img1):
? ? print("english path writing is ok!(use imwrite)")
else:
? ? print("english path writing is failed.(use imwrite)")
if cv2.imwrite(path_zh_write,img1):
? ? print("chinese path writing is ok!(use imwrite)")
else:
? ? print("chinese path writing is failed.(use imwrite)")
#借助numpy將圖像寫入含中文路徑的文件,結(jié)果成功
out = cv2.imencode(".jpg",img1)
out[1].tofile(path_zh_write)
try:
? ? f = open(path_zh_write)
? ? f.close()
? ? print("chinese path writing is ok!(use imencode and tofile)")
except:
? ? print("chinese path writing is failed.(use imencode and tofile)")

以上代碼運(yùn)行結(jié)果如下:

img1 imread ok: (129, 186, 3)
img2 imread failed.
img3 imread failed.
img4 imread failed.
img_d1 imdecode ok: (129, 186, 3)
img_d2 imdecode ok: (129, 186, 3)
img_d3 imdecode ok: (129, 186, 3)
img_d4 imdecode ok: (129, 186, 3)
english path writing is ok!(use imwrite)
chinese path writing is failed.(use imwrite)
chinese path writing is ok!(use imencode and tofile)

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論