読み込み中...

Pythonでエラーをマスターするための7つのステップ

Pythonのエラー処理を学ぶためのイラスト Python
この記事は約9分で読めます。

【サイト内のコードはご自由に個人利用・商用利用いただけます】

この記事では、プログラムの基礎知識を前提に話を進めています。

説明のためのコードや、サンプルコードもありますので、もちろん初心者でも理解できるように表現してあります。

本記事のサンプルコードを活用して機能追加、目的を達成できるように作ってありますので、是非ご活用ください。

※この記事は、一般的にプロフェッショナルの指標とされる『実務経験10,000時間以上』を満たす現役のプログラマチームによって監修されています。

※Japanシーモアは、常に解説内容のわかりやすさや記事の品質に注力しております。不具合、分かりにくい説明や不適切な表現、動かないコードなど気になることがございましたら、記事の品質向上の為にお問い合わせフォームにてご共有いただけますと幸いです。
(送信された情報は、プライバシーポリシーのもと、厳正に取扱い、処分させていただきます。)

はじめに

Pythonプログラミング言語は、そのシンプルさと広範な機能により、初心者から研究者、データ科学者まで幅広いユーザーに人気があります。

しかし、全てのプログラマーが共有する一つの経験があります。

それは、エラーと戦う経験です。

エラーは時には混乱を招くものですが、それは同時にプログラミングスキルを向上させるチャンスでもあります。

今回の記事では、Pythonでエラー処理を学ぶための7つのステップを紹介します。

●Pythonでのエラーとは

Pythonでのエラーとは、プログラムが期待通りに動作しない状態を指します。

これは、プログラムのバグ、データの不整合、外部の問題(ネットワーク接続の失敗など)など、様々な原因で起こります。

エラーは、プログラムが完全に停止するものから、予期しない動作をするものまで、さまざまな形を取ります。

●Pythonエラーの基本的な種類

Pythonのエラーは大きく分けて二つの種類があります。

○構文エラー(Syntax Errors)

構文エラーは、Pythonの構文ルールに違反しているときに発生します。

つまり、コードがPythonの文法に従っていない場合に発生します。

例えば、コロン(:)を忘れてインデントを行った場合、Pythonは構文エラーとしてこれを指摘します。

for i in range(10)
    print(i)

上記のコードは、for文の最後にコロンが欠けているため、Pythonは構文エラーを報告します。

○例外(Excepitions)

例外は、構文エラーではないが、実行時に問題が発生したときに発生します。

これには、ファイルが存在しない、データが不正である、インターネット接続が失敗するなど、多くの種類があります。

print(10 / 0)

上記のコードでは、0で除算するという操作が問題で、PythonはZeroDivisionErrorという例外を報告します。

これらのエラーと例外は、Pythonプログラミングの一部であり、これらを理解し、適切に対処する能力は、良いプログラマーになるための重要なスキルです。

それでは次に、Pythonでのエラーハンドリングについて見てみましょう。

●Pythonでのエラーハンドリング

エラーハンドリングは、エラーが発生したときに、それを適切に処理するための方法です。

Pythonでは、エラーハンドリングを行うためにtry/exceptブロックを使用します。

また、finallyとelse節もこの目的で利用できます。

○try/exceptブロックの使用

try/exceptブロックは、エラーが発生する可能性のあるコードをtryブロックに書き、そのエラーをキャッチして処理するコードをexceptブロックに書きます。

□サンプルコード1:基本的なtry/except

Pythonでエラーハンドリングを行う基本的な方法はtry/exceptブロックを使用することです。

try:
    # エラーが発生する可能性のあるコード
    print("Hello, " + name)
except:
    # エラーが発生したときに実行されるコード
    print("名前が定義されていません")

このコードでは、名前を出力しようとする行でエラーが発生する可能性があります。

なぜなら、変数nameが定義されていない可能性があるからです。

エラーが発生した場合、tryブロックの残りの部分はスキップされ、exceptブロックの内容が実行されます。

この例では、エラーメッセージ「名前が定義されていません」が表示されます。

このコードを実行すると、nameが未定義のため、出力は「名前が定義されていません」となります。

ここで注意すべきは、tryブロック内でエラーが発生すると、それ以降のtryブロック内のコードは実行されず、すぐにexceptブロックにジャンプするという点です。

□サンプルコード2:特定のエラーの捕捉

Pythonのtry/exceptブロックは、具体的なエラータイプを指定して、そのタイプのエラーだけをキャッチすることも可能です。

try:
    # エラーが発生する可能性のあるコード
    result = 10 / zero
except ZeroDivisionError:
    # ZeroDivisionErrorが発生したときに実行されるコード
    print("ゼロで除算することはできません")

このコードでは、ゼロで除算しようとすると、ZeroDivisionErrorが発生します。

except節にエラータイプを指定することで、その特定のエラーが発生したときだけ、エラーハンドリングコードが実行されます。

このコードを実行すると、「ゼロで除算することはできません」というエラーメッセージが出力されます。

これは、ゼロで除算しようとしてZeroDivisionErrorが発生したためです。

○finallyとelse節の使用

Pythonのエラーハンドリングには、try/exceptブロック以外にも、finally節とelse節を使用することができます。

finally節は、エラーの有無に関わらず最後に必ず実行されるコードを記述するためのもので、else節はエラーが発生しなかった場合にだけ実行されるコードを記述するためのものです。

□サンプルコード3:finally節の使用

finally節の使用例を紹介します。

try:
    # エラーが発生する可能性のあるコード
    result = 10 / 2
except ZeroDivisionError:
    # ZeroDivisionErrorが発生したときに実行されるコード
    print("ゼロで除算することはできません")
finally:
    # エラーの有無に関わらず最後に実行されるコード
    print("この行は必ず実行されます")

このコードでは、finally節に記述された「この行は必ず実行されます」というメッセージが、エラーが発生しようがしまいが、最終的には必ず出力されます。

□サンプルコード4:else節の使用

Pythonでエラーハンドリングを行う際、else節を使用することで、例外が発生しなかった場合に特定のコードを実行することが可能となります。以下にその具体的な例を示します。

try:
    num = int(input("数値を入力してください: "))
except ValueError:
    print("数値を入力してください。")
else:
    print(f"あなたが入力した数値は{num}です。")

このコードでは、ユーザからの入力を整数として解釈しようとします。ユーザが数値以外の文字列を入力した場合、ValueErrorが発生し、そのエラーメッセージを表示します。そうでなければ、else節が実行され、ユーザが入力した数値が表示されます。

ここで重要なのは、else節はtry節で定義されたコードが問題なく実行された場合にのみ実行される、という点です。例外が発生した場合、即座にexcept節が実行され、else節は無視されます。

●Pythonでのエラーのカスタマイズ

Pythonのエラーハンドリングでは、特定のシナリオに対応するための独自の例外を作成することも可能です。

これにより、プログラムの流れをより詳細に制御したり、エラーメッセージを具体的でわかりやすくすることができます。

○独自の例外の作成

Pythonでは、Exceptionクラスを継承することで、独自の例外を作成できます。以下に、その一例を示します。

□サンプルコード5:独自の例外の作成

class MyException(Exception):
    pass

try:
    raise MyException("これは独自の例外です")
except MyException as e:
    print(e)

このコードでは、まずExceptionクラスを継承してMyExceptionという新たな例外クラスを作成しています。

その後、try節の中でこの新たな例外を発生させ(raise)、それを捕捉してメッセージを表示しています。

このように、自分自身の例外クラスを作成することで、プログラムの特定の状況に対応したエラーハンドリングを実装できます。

例えば、特定の入力値に対するエラー、APIからの特定のレスポンスに対するエラーなど、プログラムに特有の状況を表現できます。

○エラーメッセージのカスタマイズ

Pythonの例外では、エラーメッセージをカスタマイズすることも可能です。

このカスタマイズにより、エラーの原因と解決策を具体的に示すことができます。

□サンプルコード6:エラーメッセージのカスタマイズ

class MyException(Exception):
    def __init__(self, message):
        self.message = message

try:
    raise MyException("これはカスタマイズしたメッセージです")
except MyException as e:
    print(e.message)

このコードでは、MyExceptionクラスの中にinitメソッドを定義し、エラーメッセージをインスタンス変数として保存しています。

その後、例外を発生させる際に、独自のメッセージを指定しています。

このようなカスタマイズにより、エラーの内容をより詳細に説明し、デバッグを容易にします。

●エラーハンドリングのベストプラクティス

エラーハンドリングの実装にあたり、次のベストプラクティスを覚えておくと良いでしょう。

○エラーではなく例外を使用する

Pythonでは、エラーの状況を示すために例外を使用することが推奨されています。

これは、例外がプログラムの正常な流れを中断させ、エラーハンドリングに必要なコードを明示的に実行させるからです。

○エラーの情報を適切にログする

エラーが発生した際には、エラーメッセージやスタックトレース、エラーの発生した状況など、可能な限り多くの情報をログに記録することが重要です。

これにより、エラーの原因を特定しやすくなります。

○エラーを適切に伝播する

エラーが発生した場合、そのエラーを捕捉し、必要な処理(リソースの解放、ログの記録など)を行った後、そのエラーを再度発生させることが重要です。

これにより、エラーの情報がプログラムの上位レベルに伝播し、適切なエラーハンドリングが可能になります。

まとめ

以上がPythonでエラーをマスターするための7つのステップです。

これらを順に学ぶことで、Pythonのエラー処理を理解し、コードを効率的にデバッグする能力を身につけることができます。

ここまで読んでいただき、ありがとうございました。

皆様のPythonプログラミングの学習が、一層深まることを願っています。