大xia的python学习(1)

python学习已有一周,对没太接触过语言的萌新我而言,还有挺多不明白的地方,今天起,会记录些自己在学习时的一点理解,这些经验理解仅为一家之言,若有不到位的地方,还请各路高手大侠批评指点。
今天先记录下这两天课堂上所学的内容,同时温故一下。

异常处理

(1)异常与异常处理
在介绍异常处理前,我们得先明白“异常”是什么,从字面上理解的话,它是程序在运行过程中,出现了未知的影响因素导致的不合理状况,而我们输入的代码其语法与逻辑都是对的,因为计算机并没有像我们人脑一样,能智能到可以自己绕开这些异常状况,所以才会出现异常,举个例子:

a = int(input("请输入被除数:"))
b = int(input("请输入除数:"))
print(a/b)

当a=2,b=0时,则会得到

Traceback (most recent call last):
  File "E:/MyPython/cg1.py", line 3, in <module>
    print(a/b)
ZeroDivisionError: division by zero

由于分母为0是无意义,所以才会出现ZeroDivisionError。
当我们仅输入空值时,则得到:

Traceback (most recent call last):
  File "E:/MyPython/cg1.py", line 10, in <module>
    b = int(input("请输入除数:"))
ValueError: invalid literal for int() with base 10: ''

即传入的为无效参数。
对于异常的处理方法,可以使用try…except语句,即:

try:
    a = int(input("请输入被除数:"))
    b = int(input("请输入除数:"))
    print(a/b)
    print("####我是分界线####")
except:
    print("出现异常")

使用除数为0的错误,运行结果为:

请输入被除数:10
请输入除数:0
出现异常

先进入try检测,当出现错时,就会进入except,这样就不会有报错的现象了。

(2)查看错误类型
一般较为常用的检测错误类型的方法为使用except Exception as e

try:
    a = int(input("请输入被除数:"))
    b = int(input("请输入除数:"))
    print(a/b)
    print("####我是分界线####")
except Exception as e:
    print("异常类型是",e)

(3)捕获指定错误

try:
    print(a)
except (NameError):
    print("错误")

(4)异常处理完整形式

try:
	int(input("请输入一个整数:"))
except (NameError):
    print("发生错误")
esle:
	print("没有错误")
fillanly:
	print("一定要进入")

(5)自定义异常

class MyException(Exception):
    def __init__(self):
        super().__init__()		#调用父类init()
        self.message = "答案错误"
    def __str__(self):
        return self.message

try:
    s = int(input("请输入一个整数:"))
    if s < 0:
        raise MyException()

except MyException as e:
    print("错误类型是",e)

else:
    print("答案正确")

finally:
    print("再来一次")
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表中的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库中的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表中的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库中的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值