Python第六天代码——模块

模块(module)

开发过程中,程序代码会越来越多,如果直接放在一个文件里,代码会越来越长----->代码不易维护

为了编写方便维护的代码,可以把不同功能的代码分组,保存在不同的文件里。这样,每个文件包含的代码量就会比较少,更方便维护。

在Python中,一个.py文件就可以称之为一个模块。

即:

  • 包含相应功能的函数以及变量,py则以".py"为后缀名;
  • 模块可以为其他的程序引用,以使用该模块所对应的函数或者变量。

使使用模块的好处

  • 提高代码的可维护性
  • 提高代码的复用性
  • 可以导入很多功能的模块
    • 标准库模块
    • 第三方模块
    • 自定义模块
  • 避免变量名重复(作用域)

Python中导入模块的常用方法

import 模块名称
import 模块名称 as 新模块
from 模块名称 import 函数名

区别:

  • import 模块名称和import 模块名称 as 新模块
    • 会导入整个模块
    • 如果需要使用某个函数,必须以“模块名称.函数名( )”的形式来调用相应的函数。(这种方法可以更有利于代码的可读性(优先推荐))
    • import 模块名称 as 新模块,重新命名导入的模块,通常使模块名称简洁,方便使用。
  • from 模块名称 import 函数名
    • 只导入了某一函数,而不是一整个模块
    • 可以直接函数名称去调用函数,而无需在函数名称前加模块名称
    • 如果我们的程序语句很多,不建议采用此种方法(原因:调用很多模块后,可能造成函数名重名,引发错误。)
from random import *
print(randint(1,100))

import calendar
print(calendar.month(2019,7))

注意:import语句的对应模块顺序(PEP,程序的最上方)

  • Python标准模块
  • 第三方
  • 自定义模块

错误和异常

错误

  • 语法错误(syntax error)
  • 逻辑错误(logic error)
  • 执行期间错误(runtime error)
#demo:
>>> for i in range(10)

#输出结果:
  File "<stdin>", line 1
    for i in range(10)
                     ^
SyntaxError: invalid syntax

python的语法分析器完成,检测到错误所在文件和行数。以向上箭头标记错误位置。最后显示错误类型。

当程序检测到一个错误,解释器就无法继续执行下去,抛出异常终止程序。

异常

系统根据不同的错误抛出不同的异常。

常见异常:

#ZeroDivisionError:
>>> 1/0
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ZeroDivisionError: division by zero
    
#NameError:
>>> a
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
NameError: name 'a' is not defined
    
#SyntaxError: 
>>> else a>0:
  File "<stdin>", line 1
    else a>0^
SyntaxError: invalid syntax
异常描述
NameError尝试访问一个没有申明的变量
ZeroDivisionError除数为 0
SyntaxError语法错误
IndexError索引超出序列范围
KeyError请求一个不存在的字典关键字
FileNotFoundError文件未发现错误(比如你要读的文件不存在)
AttributeError尝试访问未知的对象属性
ModuleNotFoundError模块未发现
IndentationError缩进
#indexError:
>>> li=[1,2,3]
>>> li[4]
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
IndexError: list index out of range

#keyError:
>>> dic={'name1':'cc','name2':'fs'}
>>> dic['name3']
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
KeyError: 'name3'
    
#attributeError:
>>> class Car:
...   pass
...
>>> Car.color
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AttributeError: type object 'Car' has no attribute 'color'
    
#moduleNotFoundError:
>>> import module_test
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ModuleNotFoundError: No module named 'module_test'
    
#IndentationError:
>>>  li=[1,2,3]
  File "<stdin>", line 1
    li=[1,2,3]
    ^
IndentationError: unexpected indent
异常处理

程序一旦发生错误,程序无法继续运行。

为了使程序健壮,可做相关异常处理。

try:
    try_statements
expect[exceptionType[as identifier]]:
    except_statements
[else:
    else_statements]
[finally:
    finally_statements]
  • try子句

    • try…except…必须放在可能发生异常的程序段周围,而try_statements则是可能发生异常的程序段
  • except子句

    • 用来捕捉指定的异常,一旦捕捉到,就执行与之对应的except_statements,即用来处理异常的程序语句。
    • 如果要针对不同的异常做不同的处理,可以使用多个except子句,其中,exceptionType是欲捕捉的异常类型,省略不写,表示为预设类型:BaseException,所有异常都继承自该类别。
    • [as identifier]可以将捕捉到的异常指向一个变量,然后通过该变量获得异常相关的信息。
    • 不带任何异常类型使用except,将捕获所有发生的异常。不推荐使用,因为我们不能通过该程序识别出具体的异常信息。
  • else子句

    • 当try_statements没有异常发生时,会跳过except子句,执行else_statements。
    • 该子句为可选语句,可以指定或者省略
  • finally子句

    • 当要离开try…except时(无论异常是否发生),就会执行finally_statements,可以使清除错误或者收尾的语句,可给可不给。
  • 带多个except的try语句:

try:
    ...
except exception1:
    ...
except exception2:
    ...
  • 处理多个异常的except语句:
try:
    ...
except (exception1,exception2,...,) as e:
    ...
  • 捕获所有异常:
try:
    ...
except Exception as e:
    ...
   
try:
    ...
except:
    ...
try:
    X=eval(input("请输入被除数x:\t"))
    Y=eval(input("请输入除数y:\t"))
    Z=X/Y
# except ZeroDivisionError:
#     print("除数不能为0.")
# except NameError:
#     print("请检查变量是否赋值.")
# except Exception as e:
#     print(e.args)
except (ZeroDivisionError,NameError,TypeError) as e:
    print(e.args)
    print()
# print('X/Y=',Z)
else:
    print("未捕捉到异常,X/Y=",Z)
finally:
    print("离开try...except模块。")

#输出结果:
请输入被除数x:	12
请输入除数y:	0
('division by zero',)

请输入被除数x:	12
请输入除数y:	a
("name 'a' is not defined",)

请输入被除数x:	12
请输入除数y:	3
未捕捉到异常,X/Y= 4.0
离开try...except模块。
触发异常(raise)

除了系统抛出的异常,我们可以用raise语句自己触发异常。

格式:

raise [Exception[,args[,traceback]]]

raise NameError("Sorry,Error occurs.")
##报错:
Traceback (most recent call last):
  File "scratch_31.py", line 28, in <module>
    raise NameError("Sorry,Error occurs.")
    NameError: Sorry,Error occurs.

try:
   raise NameError("Sorry,Error occurs.")
except NameError:
     print("捕捉到异常")
        
#输出结果:        
捕捉到异常
断言(assert)
assert condition

逻辑上相当于:

if not condition
    raise AssertionError()

为断言添加一个异常参数:

assert expression[,args]

#demo:

>>> assert 1==1
>>> assert 1==0
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AssertionError
>>> li=[1,2]
>>> assert len(li)>=5,"列表元素个数小于5"
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AssertionError: 列表元素个数小于5
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值