如何在Python程序中抛出异常,又不影响正常程序运行
在Python中,可以使用try...except...
语句捕获异常。如果我们在程序中遇到了异常情况,可以使用raise
语句主动抛出异常,从而触发try...except...
块中的异常处理逻辑。如果我们希望抛出异常时不影响程序的正常运行,可以在异常处理块中添加一些代码来处理或忽略异常。
下面是一个简单的示例,演示了如何在Python中抛出异常并不影响程序的正常运行:
def divide(a, b):try:# 尝试计算 a/b 的值result = a / bexcept ZeroDivisionError:# 如果 b 为 0,抛出异常raise ValueError("Cannot divide by zero.")else:# 如果计算成功,返回计算结果return resultif __name__ == '__main__':nums = [(10, 2), (5, 0), (8, 4)]for a, b in nums:try:result = divide(a, b)except ValueError as e:# 捕获异常并打印错误信息,但不会影响程序的正常运行print(f"Error: {e}")else:print(f"{a}/{b} = {result}")
在上面的示例中,我们定义了一个名为divide
的函数,它接受两个参数 a 和 b,并尝试计算 a/b 的值。如果 b 为 0,程序会抛出ValueError
异常。
在程序的主逻辑中,我们使用一个循环遍历一个包含多个数字对的列表,并依次调用divide
函数计算它们的商。如果在计算过程中出现异常,程序会捕获并打印错误信息,但不会影响后续的计算和程序的正常运行。
需要注意的是,在实际开发中,我们应该根据具体的业务需求和异常类型,合理地处理或忽略异常,避免对程序的稳定性和安全性造成影响。
自定义异常类型在实际应用中的用法和好处
假设我们正在编写一个学生信息管理系统,其中需要处理各种类型的异常,例如输入无效、文件读写错误、数据库连接失败等。我们可以定义多个自定义异常类型来表示不同类型的异常,并在程序中使用 try-except
块捕获并处理异常。以下是一个示例代码:
import csv
import sqlite3
from datetime import datetime# 自定义异常类型:无效输入异常
class InvalidInputException(Exception):def __init__(self, message):self.message = message# 自定义异常类型:文件读写异常
class FileIOException(Exception):def __init__(self, filename, mode):self.filename = filenameself.mode = mode# 自定义异常类型:数据库连接异常
class DBConnectionException(Exception):def __init__(self, message):self.message = message# 从 CSV 文件中读取学生信息
def read_student_info_from_csv(filename):try:with open(filename, "r") as f:reader = csv.reader(f)student_info_list = []for row in reader:if len(row) != 3:raise InvalidInputException("无效输入:行格式不正确")student_info_list.append(row)return student_info_listexcept FileNotFoundError:raise FileIOException(filename, "r")# 将学生信息保存到 SQLite 数据库中
def save_student_info_to_db(dbname, student_info):try:conn = sqlite3.connect(dbname)c = conn.cursor()c.execute("CREATE TABLE IF NOT EXISTS students (id INTEGER PRIMARY KEY, name TEXT, gender TEXT, birthday TEXT)")c.executemany("INSERT INTO students(name, gender, birthday) values (?, ?, ?)", student_info)conn.commit()conn.close()except sqlite3.Error as e:raise DBConnectionException("数据库连接异常:{}".format(str(e)))# 主函数
def main():try:student_info_list = read_student_info_from_csv("student_info.csv")save_student_info_to_db("student_info.db", student_info_list)print("学生信息保存成功!")except InvalidInputException as e:print("无效输入异常:{}".format(e.message))except FileIOException as e:print("文件读写异常:无法打开文件 {},模式为 {}".format(e.filename, e.mode))except DBConnectionException as e:print(e.message)if __name__ == "__main__":main()
在上述代码中,我们定义了三个自定义异常类型 InvalidInputException
、FileIOException
和 DBConnectionException
,用于表示不同类型的异常。
在函数 read_student_info_from_csv
中,我们尝试从 CSV 文件中读取学生信息。如果读取过程中发现行格式不正确,则抛出 InvalidInputException
异常;如果文件不存在,则抛出 FileIOException
异常。
在函数 save_student_info_to_db
中,我们将读取到的学生信息保存到 SQLite 数据库中。如果连接数据库时出现异常,则抛出 DBConnectionException
异常。
在主函数中,我们使用 try-except
块捕获并处理不同类型的异常,以便更好地处理错误情况并提供有用的信息。