[Python ]在影像處理中使用 raise 關鍵字手動觸發錯誤

更新於 2024/09/09閱讀時間約 1 分鐘

在 Python 中,你可以使用 raise 關鍵字手動觸發錯誤。這對於測試異常處理或在特定情況下停止程式執行非常有用。

本文主說明在影像處理中常見的異常情況,展示如何使用 raise 來觸發不同類型的錯誤。


1. 檔案不存在 (FileNotFoundError)

在影像處理中,如果要讀取的影像檔案不存在,可以手動觸發 FileNotFoundError

import cv2

def load_image(file_path):
image = cv2.imread(file_path)
if image is None:
raise FileNotFoundError(f"檔案不存在: {file_path}")
return image

try:
img = load_image("non_existent_image.jpg")
except FileNotFoundError as e:
print(f"捕捉到錯誤: {e}")



raw-image


2. 不支持的影像格式 (ValueError)

當影像格式不正確時,你可以手動觸發 ValueError,避免後續處理錯誤。

import cv2

def check_image_format(image, required_channels=3):
if image is None:
raise ValueError("無法讀取影像")
if len(image.shape) != 3 or image.shape[2] != required_channels:
raise ValueError(f"需要 {required_channels} 通道的影像,但得到 {len(image.shape)} 通道")
return True

try:
# 讀取原圖
image = cv2.imread('F:/python/opencv/ball/123_out.png')
# 將圖像轉為灰階
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
check_image_format(gray_image, 3) # 檢查是否為 RGB 三通道影像
except ValueError as e:
print(f"捕捉到錯誤: {e}")
raw-image


3. 大小不匹配 (ValueError)

當你處理多張影像且要求影像大小一致時,如果影像尺寸不匹配,可以觸發 ValueError

import cv2

def check_same_size(image1, image2):
if image1.shape != image2.shape:
raise ValueError("影像大小不匹配")
return True

try:
img1 = cv2.imread("image1.jpg")
img2 = cv2.imread("image2.jpg")
check_same_size(img1, img2)
except ValueError as e:
print(f"捕捉到錯誤: {e}")
raw-image

4. 無效的參數類型 (TypeError)

當函數參數的類型不正確時,觸發 TypeError

import cv2

def resize_image(image, width, height):
if not isinstance(width, int) or not isinstance(height, int):
raise TypeError("寬度和高度必須是整數")
return cv2.resize(image, (width, height))

try:
img = cv2.imread("example_image.jpg")
resized_img = resize_image(img, "800", 600) # 傳入錯誤類型的寬度
except TypeError as e:
print(f"捕捉到錯誤: {e}")
raw-image

5. 影像處理失敗 (RuntimeError)

當某個影像處理操作無法成功執行時,可以手動觸發 RuntimeError

import cv2

def apply_canny_edge_detection(image):
edges = cv2.Canny(image, 100, 200)
if edges is None:
raise RuntimeError("Canny 邊緣檢測失敗")
return edges

try:
img = cv2.imread("example_image.jpg", 1) # 讀取灰階影像
edges = apply_canny_edge_detection(img)
except RuntimeError as e:
print(f"捕捉到錯誤: {e}")
raw-image

6. 過多的雜訊 (ValueError)

當影像雜訊過多或不符合預期標準時,可以觸發 ValueError

import cv2
import numpy as np

def check_image_noise_level(image, threshold):
noise_level = np.std(image)
if noise_level > threshold:
raise ValueError(f"影像雜訊過高: {noise_level}, 超過閾值: {threshold}")
return True

try:
img = cv2.imread("noisy_image.jpg", 0)
check_image_noise_level(img, 25)
except ValueError as e:
print(f"捕捉到錯誤: {e}")
raw-image

7. 找不到輪廓 (ValueError)

在找不到圖像中的輪廓時,可以手動觸發 ValueError

import cv2

def find_largest_contour(image):
contours, _ = cv2.findContours(image, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
if len(contours) == 0:
raise ValueError("無法找到任何輪廓")
largest_contour = max(contours, key=cv2.contourArea)
return largest_contour

try:
img = cv2.imread("example_image.jpg", 0) # 讀取灰階影像
largest_contour = find_largest_contour(img)
except ValueError as e:
print(f"捕捉到錯誤: {e}")
raw-image

結論

根據不同的異常情況手動使用 raise 來觸發錯誤。這種方法有助於在影像處理過程中提早發現問題並進行處理,增強程式的穩定性。後續維護debug也比較簡單。

avatar-img
128會員
209內容數
本業是影像辨識軟體開發,閒暇時間進修AI相關內容,將學習到的內容寫成文章分享。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
螃蟹_crab的沙龍 的其他內容
在影像處理中,有時候我們只想特別關注某個感興趣的區域時,就是ROI的概念,擷取此範圍的圖像來做處理。 設定超過圖像邊界時就會報錯,本文主要介紹如何擷取影像的同時,避免設定錯誤造成程式崩潰的狀況。 擷取圖像示意圖 ROI程式範例 import cv2 import numpy as np
使用cv2.imread讀取圖片時,如果路徑有包含到中文,就會報錯。 本文將提供另外一個方式cv2.imdecode,路徑有包含到中文時仍可以正常讀取圖片。 測試範例 import cv2 img = cv2.imread('D:/CRABpy/write/圖檔/chars_01.png'
在影像處理中,有時候我們只想特別關注某個感興趣的區域時,就是ROI的概念,擷取此範圍的圖像來做處理。 設定超過圖像邊界時就會報錯,本文主要介紹如何擷取影像的同時,避免設定錯誤造成程式崩潰的狀況。 擷取圖像示意圖 ROI程式範例 import cv2 import numpy as np
使用cv2.imread讀取圖片時,如果路徑有包含到中文,就會報錯。 本文將提供另外一個方式cv2.imdecode,路徑有包含到中文時仍可以正常讀取圖片。 測試範例 import cv2 img = cv2.imread('D:/CRABpy/write/圖檔/chars_01.png'
你可能也想看
Google News 追蹤
Thumbnail
徵的就是你 🫵 超ㄅㄧㄤˋ 獎品搭配超瞎趴的四大主題,等你踹共啦!還有機會獲得經典的「偉士牌樂高」喔!馬上來參加本次的活動吧!
Thumbnail
隨著理財資訊的普及,越來越多台灣人不再將資產侷限於台股,而是將視野拓展到國際市場。特別是美國市場,其豐富的理財選擇,讓不少人開始思考將資金配置於海外市場的可能性。 然而,要參與美國市場並不只是盲目跟隨標的這麼簡單,而是需要策略和方式,尤其對新手而言,除了選股以外還會遇到語言、開戶流程、Ap
Thumbnail
特徵工程是機器學習中的核心技術,通過將原始數據轉換為有意義的特徵,以提升模型的準確性和穩定性。常見的特徵工程方法包括異常值檢測、特徵轉換、特徵縮放、特徵表示、特徵選擇和特徵提取。本文將深入探討這些方法的適用情況及具體實施流程,以幫助讀者有效利用特徵工程來優化機器學習模型表現。
Thumbnail
在影像處理中,有時候我們只想特別關注某個感興趣的區域時,就是ROI的概念,擷取此範圍的圖像來做處理。 設定超過圖像邊界時就會報錯,本文主要介紹如何擷取影像的同時,避免設定錯誤造成程式崩潰的狀況。 擷取圖像示意圖 ROI程式範例 import cv2 import numpy as np
Thumbnail
在某些特殊情況下,需要將圖片進行黑白反轉,例如Tesseract(OCR辨識引擎)就有建議黑底白字的狀況下辨識率較高。 本文將使用 NumPy 進行影像黑白反轉,並顯示反轉前後的影像。
Thumbnail
在影像辨識中,若遇到物件與背景難以分辨的狀況下,先做一下色彩分析,知道了色彩強度階層上的像素數,有助於了解後續需要做什麼處理,比較好分割出辨識物。 若想辨識的物件與背景的RGB值過於接近,也比較好說明此狀況,為什麼較難分割出物件。 成果呈現 第一張圖:左邊為原圖,右邊為分析結果的圖,用其他顏
Thumbnail
這是什麼大問題嗎?這樣就寫一篇文章,會不會太混了! 會! 其實蠻混的! 哈哈哈! 1.英文不好,乾脆用中文。就用微軟 Copilot 設計工具 的網址在此。好啦!
Thumbnail
形態學操作在影像處理中有多種應用,特別是在處理二值化影像(黑白影像)。 在影像處理應用上,基本上都由侵蝕,膨脹這兩種方法,組合搭配而成。 常見應用場景 物體檢測與分割: 形態學操作可以用於增強或改善二值化影像中的物體邊界,使得物體的檢測和分割更加準確。
Thumbnail
本文將介紹影像的基本操作包括:影像的讀取、顯示、保存,以及一些常見的操作如裁剪、旋轉、縮放等。 語法介紹 讀取影像: cv2.imread函數的參數是影像的檔案路徑。讀取後的影像以NumPy的ndarray形式表示。
Thumbnail
影片剪輯比較複雜 創作者不但要能文能武,還需要會影片剪輯。影片剪輯說起來就比較複雜,因為牽涉到比較多的面向。剛開始入手的時候很難理解,不過了解系統架構以後,其實也就那麼一回事。但是總得來說,耗時相對要多很多,比起一般的文章或繪圖,你也可能要耗時許多,因為他的素材就是比較多。 聲音素材、圖片素材、
Thumbnail
[影像處理_OpenCV Python]使用Python撰寫影像處理功能,圖片遮罩或濾除掉不要的地方,旋轉圖片 以下範例將呈現影像處理三種不同的應用: 遮罩的實現 濾除 旋轉
Thumbnail
徵的就是你 🫵 超ㄅㄧㄤˋ 獎品搭配超瞎趴的四大主題,等你踹共啦!還有機會獲得經典的「偉士牌樂高」喔!馬上來參加本次的活動吧!
Thumbnail
隨著理財資訊的普及,越來越多台灣人不再將資產侷限於台股,而是將視野拓展到國際市場。特別是美國市場,其豐富的理財選擇,讓不少人開始思考將資金配置於海外市場的可能性。 然而,要參與美國市場並不只是盲目跟隨標的這麼簡單,而是需要策略和方式,尤其對新手而言,除了選股以外還會遇到語言、開戶流程、Ap
Thumbnail
特徵工程是機器學習中的核心技術,通過將原始數據轉換為有意義的特徵,以提升模型的準確性和穩定性。常見的特徵工程方法包括異常值檢測、特徵轉換、特徵縮放、特徵表示、特徵選擇和特徵提取。本文將深入探討這些方法的適用情況及具體實施流程,以幫助讀者有效利用特徵工程來優化機器學習模型表現。
Thumbnail
在影像處理中,有時候我們只想特別關注某個感興趣的區域時,就是ROI的概念,擷取此範圍的圖像來做處理。 設定超過圖像邊界時就會報錯,本文主要介紹如何擷取影像的同時,避免設定錯誤造成程式崩潰的狀況。 擷取圖像示意圖 ROI程式範例 import cv2 import numpy as np
Thumbnail
在某些特殊情況下,需要將圖片進行黑白反轉,例如Tesseract(OCR辨識引擎)就有建議黑底白字的狀況下辨識率較高。 本文將使用 NumPy 進行影像黑白反轉,並顯示反轉前後的影像。
Thumbnail
在影像辨識中,若遇到物件與背景難以分辨的狀況下,先做一下色彩分析,知道了色彩強度階層上的像素數,有助於了解後續需要做什麼處理,比較好分割出辨識物。 若想辨識的物件與背景的RGB值過於接近,也比較好說明此狀況,為什麼較難分割出物件。 成果呈現 第一張圖:左邊為原圖,右邊為分析結果的圖,用其他顏
Thumbnail
這是什麼大問題嗎?這樣就寫一篇文章,會不會太混了! 會! 其實蠻混的! 哈哈哈! 1.英文不好,乾脆用中文。就用微軟 Copilot 設計工具 的網址在此。好啦!
Thumbnail
形態學操作在影像處理中有多種應用,特別是在處理二值化影像(黑白影像)。 在影像處理應用上,基本上都由侵蝕,膨脹這兩種方法,組合搭配而成。 常見應用場景 物體檢測與分割: 形態學操作可以用於增強或改善二值化影像中的物體邊界,使得物體的檢測和分割更加準確。
Thumbnail
本文將介紹影像的基本操作包括:影像的讀取、顯示、保存,以及一些常見的操作如裁剪、旋轉、縮放等。 語法介紹 讀取影像: cv2.imread函數的參數是影像的檔案路徑。讀取後的影像以NumPy的ndarray形式表示。
Thumbnail
影片剪輯比較複雜 創作者不但要能文能武,還需要會影片剪輯。影片剪輯說起來就比較複雜,因為牽涉到比較多的面向。剛開始入手的時候很難理解,不過了解系統架構以後,其實也就那麼一回事。但是總得來說,耗時相對要多很多,比起一般的文章或繪圖,你也可能要耗時許多,因為他的素材就是比較多。 聲音素材、圖片素材、
Thumbnail
[影像處理_OpenCV Python]使用Python撰寫影像處理功能,圖片遮罩或濾除掉不要的地方,旋轉圖片 以下範例將呈現影像處理三種不同的應用: 遮罩的實現 濾除 旋轉