1. 程式人生 > >Python 中 'unicodeescape' codec can't decode bytes in position XXX: trun { cv.imread()的使用)}錯誤解決方案

Python 中 'unicodeescape' codec can't decode bytes in position XXX: trun { cv.imread()的使用)}錯誤解決方案

背景描述

  • 今天在運用Python pillow模組處理圖片時遇到一個錯誤
cv.imread("D:\image\1.jpg")
  • 然後報錯
SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes in position 2-3: truncated \UXXXXXXXX escape1

剛開始以為是圖片名字有中文,不識別,於是在python檔案的頭部加上 #-- coding:utf-8 --1 但是加完這個還是報錯,然後我就把圖片的中文去掉還成英文,然後報錯,一臉懵逼呀。後來在stackoverflow 上找到了類似的錯誤,原來是圖片路徑寫的 有問題,錯誤程式碼如下

im = Image.open('C:\Users\FrankYuan\Pictures\Camera Roll\WIN_20161010_08_51_57_Pro.jpg')1
  • 正確結果

    im = Image.open(‘C:\Users\FrankYuan\Pictures\Camera Roll\WIN_20161010_08_51_57_Pro.jpg’)

或者

im = Image.open(r'C:\Users\FrankYuan\Pictures\Camera Roll\WIN_20161010_08_51_57_Pro.jpg')

抑或

im = Image.open(r'C:/Users/FrankYuan/Pictures/Camera Roll/WIN_20161010_08_51_57_Pro.jpg')

原因分析

window 讀取檔案可以用\,但是在字串中\是被當作轉義字元來使用,所以’d:\a.txt’會被轉義成’d:\a.txt’這是正確路徑,所以不會報錯。而‘C:\Users\FrankYuan\Pictures\Camera Roll\WIN_20161010_08_51_57_Pro.jpg ’中經過轉義之後可能就找不到路徑的資源了,例如\t可能就轉義成tab鍵了。

解決辦法

python在描述路徑時可以有多種方式,現列舉常見的三種

方式一:轉義的方式

‘d:\a.txt’

方式二:顯式宣告字串不用轉義

‘d:r\a.txt’

方式三:使用Linux的路徑/

'd:/a.txt’1234567891011

我強烈推薦第三種寫法,這在Linux和window下都是行的通的。

轉載自