解決python cv2.imread 讀取中文路徑的圖片返回為None的問題
使用cv2讀取圖片時,輸出圖片形狀大小時出現報錯“ ’NoneType’ object has no attribute shape”,后來排查發現讀取圖片的返回值image為None, 這就說明圖片根本就沒有被讀取。
下面圖片是問題問題解決后,為了更好的展示,寫的代碼展示,這是正常的因果關系,找錯誤排查時是從下往上推。
使用PIL讀取圖像,能夠成功讀取圖片,借此了解圖片的大小和格式,代碼如下圖所示:
cv.imread函數能夠成功讀取非中文路徑的圖片,所以就想到是不是中文路徑的問題,opencv中opencv不接受non-ascii的路徑,解決方法就是先用先用np.fromfile()讀取為np.uint8格式,再使用cv2.imdecode()解碼,如下:
np.fromfile(filename, dtype)是從以dtype形式讀取文件
cv2.imdecode()函數從指定的內存緩存中讀取數據,并把數據轉換(解碼)成圖像格式;主要用于從網絡傳輸數據中恢復出圖像
補充知識:python3.x, cv2.imread()導入圖片失敗,none
首先在第一次運行時,命令行中錯誤:
ValueError: embedded null character
發現是因為導入的圖片路徑中存在0
python3.x, cv2.imread()導入圖片失敗,none
1. 路徑中無中文名
2. pip list 發現也有opencv-python,(雖然我又重新下了一遍
而這些圖片用PS打開的時候,會報錯:無法完成請求,因為找到不知名的或無效的JPEG標識符類型
圖片是我從網站上爬下來的,改過其后綴名為jpg, 源圖真正的后綴名是gif.
所以要重置一些文件的格式,比如用畫圖重新保存為jpg格式。
這里注意:
后綴是一個標簽,表明文件的類型和格式,至于文件到底是不是該格式就另說了。有時候改了后綴名,文件仍能被打開(我遇到的情況),是因為文件內容還有文件頭,有些應用程序會根據文件頭中的信息來判斷文件的格式(比如windows自帶的照片查看器)而不是通過后綴名。所以切實有效的方式還是通過格式轉換軟件來轉換格式。
應用python PIL包的Image模塊將圖片重新轉換格式為jpg(徹底轉換格式,而不是只改后綴)
(當然如果只需要幾張圖的話,直接用畫圖打開另存jpg格式就好了)
img = Image.open(file_path+’/’+files[j]).convert(’RGB’)img.save(file_path+’/’+files[j]
注意要有個convert(’RGB’),不然報錯OSError: cannot write mode P as JPEG
以上這篇解決python cv2.imread 讀取中文路徑的圖片返回為None的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。
相關文章: