カテゴリ: Python 更新日: 2025/12/13

Pythonのカスタム例外を完全ガイド!初心者でもわかる独自Exceptionクラスの作り方

Pythonのカスタム例外を作成する方法(独自のExceptionクラス)
Pythonのカスタム例外を作成する方法(独自のExceptionクラス)

先生と生徒の会話形式で理解しよう

生徒

「先生、Pythonでエラーが出たときに、自分で好きなメッセージを作ったり、決まった形の例外を作ったりできますか?」

先生

「もちろんできますよ。Pythonでは、カスタム例外と呼ばれる独自のエラークラスを作ることができるんです。」

生徒

「カスタム例外ってどんなときに役立つんですか?普通の例外だけじゃだめなんですか?」

先生

「普通の例外でも十分な場合はあります。でも、大きいプログラムになったり人と共同で作るときは、専用の例外があると原因がすぐに分かるので、とても便利なんです。」

生徒

「なるほど!まずは基本から知りたいです!」

-

1. Pythonのカスタム例外とは?

1. Pythonのカスタム例外とは?
1. Pythonのカスタム例外とは?

Pythonのカスタム例外とは、自分で作成する独自のエラークラスのことです。例えば、資料の入力が間違っているときや、データの形式が想定と違うときなど、特定の状況を分かりやすく伝えるために利用します。大規模なアプリケーションや複雑な処理では、どこで何が原因でエラーになったのかをはっきりさせることがとても重要です。カスタム例外はプログラムの見通しを良くし、保守も簡単になります。

2. カスタム例外を作る基本(独自のExceptionクラス)

2. カスタム例外を作る基本(独自のExceptionクラス)
2. カスタム例外を作る基本(独自のExceptionクラス)

Pythonでカスタム例外を作る方法はとてもシンプルです。標準で用意されているExceptionクラスを継承して、自分専用のクラスを作るだけです。名前はエラー内容が想像しやすいようにするのがポイントです。


class InvalidAgeError(Exception):
    pass

このように書くと、InvalidAgeErrorという新しい例外が誕生します。これを実際のプログラムで使うと、年齢入力が間違っていることを明確に伝えることができます。

3. カスタム例外を実際に使ってみよう

3. カスタム例外を実際に使ってみよう
3. カスタム例外を実際に使ってみよう

たとえば、年齢を入力してもらう小さなプログラムを作るとします。数字ではない文字が入ったときや、ありえない数字が入ったときにカスタム例外で知らせてあげるととても分かりやすい動作になります。


class InvalidAgeError(Exception):
    def __init__(self, age):
        self.age = age
        super().__init__(f"{age} は正しい年齢ではありません。")

def check_age(age):
    if age < 0 or age > 150:
        raise InvalidAgeError(age)
    return "年齢は正しく入力されています。"

try:
    result = check_age(-5)
    print(result)
except InvalidAgeError as e:
    print("カスタム例外が発生しました:", e)

カスタム例外が発生しました: -5 は正しい年齢ではありません。

4. try / except / else / finally の流れも理解しよう

4. try / except / else / finally の流れも理解しよう
4. try / except / else / finally の流れも理解しよう

例外処理の流れを理解すると、カスタム例外をどこでどのように扱うべきかが自然と分かるようになります。tryは危険な処理を入れる場所、exceptは例外が起きたときの対処、elseは成功したときの処理、finallyは必ず実行する処理をまとめます。


try:
    print("データを読み込みます")
except Exception:
    print("エラーが発生しました")
else:
    print("問題ありませんでした")
finally:
    print("処理を終了します")
-

5. カスタム例外を使うメリット

5. カスタム例外を使うメリット
5. カスタム例外を使うメリット

カスタム例外の大きなメリットは、原因がすぐに分かるという点です。例えば、入力エラー、ネットワークエラー、権限エラーなど、種類ごとにクラスを作っておけば、except文で的確に処理できます。また、ログを記録する際にも、どの種類のエラーが起きたかを分けて保存できるため、後から調査がしやすくなります。

6. 実務でよく使われるカスタム例外の例

6. 実務でよく使われるカスタム例外の例
6. 実務でよく使われるカスタム例外の例

実務では、入力のチェック、APIの通信失敗、ファイルの読み取りミスなど、専用の例外があるととても便利です。チーム開発では、例外の名前とルールを統一すると、プログラムの品質が安定し、保守性も大きく向上します。データベース処理でも「データが見つからないエラー」などをカスタム例外化することがよくあります。

7. カスタム例外を階層化して整理する方法

7. カスタム例外を階層化して整理する方法
7. カスタム例外を階層化して整理する方法

大きなプロジェクトでは、例外を階層化して整理することも重要です。共通の親クラスを作り、その下に細かいエラーを並べることで、ある種類のエラーだけをまとめて捕捉することができます。この仕組みは、後からエラーを増やしたいときにも柔軟に対応できます。


class AppError(Exception):
    pass

class DataNotFoundError(AppError):
    pass

class PermissionDeniedError(AppError):
    pass

このように階層化しておけば、AppErrorをexceptで受け取るだけで共通の処理が可能になります。

コメント
コメント投稿は、ログインしてください

まだ口コミはありません。

関連記事:
カテゴリの一覧へ
新着記事
New1
PHP
PHPのマルチバイト文字列を正しく扱う方法!初心者向けにmb_strlenとmb_substrをやさしく解説
New2
PHP
PHP の break, continue の使い方を完全解説!初心者でもわかるループ制御
New3
Python
Pythonで日本の元号を扱う方法を徹底解説!令和・平成の変換もバッチリ対応
New4
Python
Pythonの三項演算子とは?一行で条件分岐を記述する方法
-
人気記事
No.1
Java&Spring記事人気No1
Python
Pythonで辞書のキー・値・アイテムを取得する方法(keys(), values())
No.2
Java&Spring記事人気No2
Python
Pythonでエラースタックトレースを表示・取得する方法を徹底解説!初心者向け例外処理入門
No.3
Java&Spring記事人気No3
Python
Pythonで辞書のネスト構造(入れ子辞書)を扱う方法 初心者向け完全ガイド
No.4
Java&Spring記事人気No4
Python
Pythonのライブラリとは?標準ライブラリとサードパーティライブラリの違いを初心者向けに解説!
No.5
Java&Spring記事人気No5
Python
PythonでMySQLに接続する方法を完全解説!初心者でもわかるpymysqlの基本
No.6
Java&Spring記事人気No6
PHP
PHPで画像ファイルをアップロードする方法を初心者向けに徹底解説!わかりやすい画像処理入門
No.7
Java&Spring記事人気No7
PHP
PHP の基本構文(開始タグ・コメント・インデント)を完全ガイド!初心者向け解説
No.8
Java&Spring記事人気No8
PHP
PHP のデータ型を完全ガイド!初心者でもわかる int, string, float, bool など
-
-