学习目标:
- 能够说出包的作用
- 知道使用import包名.模块名能够导入包中的模块
- 知道使用from包名.模块名import...能够导入模块中的符号
- 知道包中__init__.py文件的作用
- 了解PEP8代码规范
- 能够完成面向对象版学生名片管理系统案例:增、删、改、查
01_Python中的包
学习目标:
- 能够说出包的作用
- 知道使用 import 包名.模块名 能够导入包中的模块
- 知道使用 from 包名.模块名 import...能够导入模块中的符号
- 知道包中__init__.py文件的作用
1.1 创建包
-
有 2 个模块功能有些联系,可以将其放到同一个文件夹下
-
要组成包,还需要在该文件夹中创建__init__.py文件
有 2 个模块功能有些联系,可以将其放到同一个文件夹下
要组成包,还需要在该文件夹中创建__init__.py文件
总结:
-
把有联系的多个模块文件,放到同一个文件夹下,并且在这个文件夹创建一个名字为__init__.py 文件,那么这个文件夹就称之为包
-
包的本质就是一个文件夹,包的作用将模块文件组织起来
-
包能有效避免模块名称冲突问题,提高程序的结构性和可维护性
1.2 导入包中模块
- 使用 import 包名.模块名 能够导入包中的模块
- 使用 from 包名.模块名 import...能够导入模块中的符号
示例代码:
"""
方式1:
导入格式: import 包名.模块名
包名就是文件夹名 模块名就是文件名字
使用格式: 包名.模块名.工具 (类名、函数、变量)
"""
import msg.sendmsg
msg.sendmsg.send_test()
"""
方式2:
导入格式: from 包名.模块名 import 所需的工具
使用格式: 工具 (类名、函数、变量)
"""
from msg.sendmsg import send_test
# from msg.sendmsg import *
send_test()
1.3 __init__.py文件有什么用
-
包被导入时,会执行 __init__.py文件的内容
-
__init__.py 的作用:控制包的导入行为,管理模块文件
1.3.1 导包执行__init__.py内容
- 包被导入时,会执行 __init__.py文件的内容
1.3.2 控制导入模块
1.4 [补充内容]列表和字典拆包传参
包被导入时,会执行 __init__.py文件的内容
__init__.py 的作用:控制包的导入行为,管理模块文件
- 包被导入时,会执行 __init__.py文件的内容
学习目标:
理解列表和字典拆包传参的形式
# *args:元组不定长参数
# **kwargs:字典不定长参数
def func(*args, **kwargs):
print(type(args), args) # tuple元祖:(1, 2, 5)
print(type(kwargs), kwargs) # dict字典:{'a': 1, 'b': 3, 'c': 5}
# 调用 func 函数
# func(1, 2, 5, a=1, b=3, c=5)
def sum(a, b):
print(f'a:{a}, b:{b}')
return a + b
my_list = [1, 2]
# 需求1:调用 sum 函数,并将 my_list 中的 1 和 2 分别传递给形参 a 和 b
# res = sum(my_list[0], my_list[1])
# 调用函数时,在传递实参时在列表前添加*,表示将列表中的每个元素取出,按照顺序给函数传实参
res = sum(*my_list) # 等价于sum(my_list[0], my_list[1])
print(res)
print('=' * 20)
my_dict = {'a': 2, 'b': 3}
# 需求2:调用 sum 函数,并将 my_dict 中的 2 和 3 分别传递给形参 a 和 b
# res = sum(my_dict['a'], my_dict['b'])
# 调用函数时,在传递实参时在字典前添加**,表示将字典拆包传递实参:key=value、key=value...
res = sum(**my_dict) # 等价 sum(a=2, b=3)
print(res)
1.5 [补充内容]列表和字典拆包传参
学习目标:
知道python中万物皆'对象'
# 定义一个空列表
my_list = []
print(type(my_list), my_list)
my_list = list()
print(type(my_list), my_list)
print('=' * 20)
# 定义一个空字典
my_dict = {}
print(type(my_dict), my_dict)
my_dict = dict()
print(type(my_dict), my_dict)
my_dict = {'a': 1, 'b': 3, 'c': 2}
for key, value in my_dict.items():
# print(type(item), item)
print(key, value)
1.6 [补充内容]函数递归调用
学习目标:
了解函数递归调用的过程
"""
在一个函数的内部,又去调用自身,这就是函数递归调用【自己调用自己】
注意:函数递归调用一般会在特定情况下不再调用函数本身(一定要有出口),否则会导致到达最大递归次数, 程序报错
"""
"""
通过递归函数实现求阶乘
1! = 1
2! = 2 × 1 = 2 × 1!
3! = 3 × 2 × 1 = 3 × 2!
4! = 4 × 3 × 2 × 1 = 4 × 3!
...
n! = n × (n-1)!
"""
# 需求:封装一个函数,计算 n 的阶乘
def func(n):
"""计算n的阶乘并返回结果"""
if n == 1:
return 1
else:
return n * func(n-1)
res = func(3)
print(res)
res = func(4)
print(res)
# 需求:封装一个函数,计算1-n的和
# n=1,和:1
# n=2:和:2 + 1
# n=3:和:3 + 1
# n:func(n) = n + func(n-1)
def func_sum(n):
"""计算1-n的和"""
if n == 1:
return 1
else:
return n + func_sum(n-1)
res = func_sum(4)
print(res)
02_PEP8: Python代码风格指南
学习目标:
- 了解PEP8代码规范
PEP8代码规范
PEP8 提供了 Python 代码的编写约定,本节知识点旨在提高代码的可读性,并使其在各种 Python 代码中编写风格保持一致。
1) 缩进使用4个空格, 空格是首选的缩进方式. Python3 不允许混合使用制表符和空格来缩进.
2)每一行最大长度限制在79个字符以内.
3)顶层函数、类的定义, 前后使用两个空行隔开.
4)import 导入
(1)导入建议在不同的行, 例如:
import os import sys # 不建议如下导包 import os, sys # 但是可以如下: from subprocess import Popen, PIPE
(2)导包位于文件顶部, 在模块注释、文档字符串之后, 全局变量、常量之前. 导入按照以下顺序分组:
a. 标准库导入
b. 相关第三方导入
c. 本地应用/库导入
d. 在每一组导入之间加入空行
5)Python 中定义字符串使用双引号、单引号是相同的, 尽量保持使用同一方式定义字符串. 当一个字符串包含单引号或者双引号时, 在最外层使用不同的符号来避免使用反斜杠转义, 从而提高可读性.
6)表达式和语句中的空格:
(1)避免在小括号、方括号、花括号后跟空格.
(2)避免在逗号、分号、冒号之前添加空格.
(3)冒号在切片中就像二元运算符, 两边要有相同数量的空格. 如果某个切片参数省略, 空格也省略.
(4)避免为了和另外一个赋值语句对齐, 在赋值运算符附加多个空格.
(5)避免在表达式尾部添加空格, 因为尾部空格通常看不见, 会产生混乱.
(6)总是在二元运算符两边加一个空格, 赋值(=),增量赋值(+=,-=),比较(==,<,>,!=,<>,<=,>=,in,not,in,is,is not),布尔(and, or, not
7)避免将小的代码块和 if/for/while 放在同一行, 要避免代码行太长.
if foo == 'blah': do_blah_thing() for x in lst: total += x while t < 10: t = delay()
8)永远不要使用字母 'l'(小写的L), 'O'(大写的O), 或者 'I'(大写的I) 作为单字符变量名. 在有些字体里, 这些字符无法和数字0和1区分, 如果想用 'l', 用 'L' 代替.
9)类名一般使用首字母大写的约定.
10)函数名应该小写, 如果想提高可读性可以用下划线分隔.
11)如果函数的参数名和已有的关键词冲突, 在最后加单一下划线比缩写或随意拼写更好. 因此 class_ 比 clss 更好.(也许最好用同义词来避免这种冲突).
12)方法名和实例变量使用下划线分割的小写单词, 以提高可读性.
03_学生名片管理系统:面向对象版
学习目标:
- 能够完成面向对象版学生名片管理系统案例:增、删、改、查



