Python面向对象——模块和包

Python面向对象——模块和包

01 模块

(1)模块的概念

模块是 Python 程序架构的一个核心概念

每一个以扩展名 py 结尾的 Python 源代码文件都是一个 模块
模块名 同样也是一个 标识符,需要符合标识符的命名规则
在模块中定义的 全局变量、函数、类 都是提供给外界直接使用的 工具
模块 就好比是 工具包,要想使用这个工具包中的工具,就需要先 导入 这个模块

(2)模块的两种导入方式

1)import 导入

在这里插入图片描述
提示:在导入模块时,每个导入应该独占一行
在这里插入图片描述
导入之后
通过 模块名. 使用 模块提供的工具——全局变量、函数、类

模块1:

# 全局变量
title = "模块1"

# 函数
def say_hello():
    print("我是 %s" %title)

# 类
class Dog(object):
    pass

模块2:

# 全局变量
title = "模块2"

# 函数
def say_hello():
    print("我是 %s" % title)

# 类
class Cat(object):
    pass

导入模块:

import 模块1
import 模块2

模块1.say_hello()
模块2.say_hello()

dog = 模块1.Dog()
print(dog)

cat = 模块2.Cat()
print(cat)

在这里插入图片描述
使用 as 指定模块的别名
如果模块的名字太长,可以使用 as 指定模块的名称,以方便在代码中的使用
在这里插入图片描述
注意:模块别名 应该符合 大驼峰命名法

import 模块1 as DogModule
import 模块2 as CatModule

DogModule.say_hello()
CatModule.say_hello()

dog = DogModule.Dog()
print(dog)

cat = CatModule.Cat()
print(cat)

在这里插入图片描述

2)from…import 导入

如果希望 从某一个模块 中,导入 部分 工具,就可以使用 from…import 的方式
import 模块名一次性 把模块中 所有工具全部导入,并且通过 模块名/别名 访问
在这里插入图片描述
导入之后
  不需要 通过 模块名.
  可以直接使用 模块提供的工具——全局变量、函数、类

from 模块1 import Dog
from 模块2 import say_hello

say_hello()

wangcai = Dog()
print(wangcai)

在这里插入图片描述

注意
如果两个模块,存在同名的函数,那么后导入模块的函数,会覆盖掉先导入的函数

开发时 import 代码应该统一写在 代码的顶部,更容易及时发现冲突
一旦发现冲突,可以使用 as 关键字 给其中一个工具起一个别名
在这里插入图片描述
在这里插入图片描述
取别名后:
在这里插入图片描述
在这里插入图片描述
from…import * (知道)
在这里插入图片描述
注意
这种方式不推荐使用,因为函数重名并没有任何的提示,出现问题不好排查

只导入模块1时:

from 模块1 import *

print(title)
say_hello()

wangcai = Dog()
print(wangcai)

在这里插入图片描述
导入模块2后:

from 模块1 import *
from 模块2 import *

print(title)
say_hello()

wangcai = Dog()
print(wangcai)

在这里插入图片描述

(3)模块的搜索顺序[扩展]

Python 的解释器在导入模块时,会:
1.搜索当前目录指定模块名的文件,如果有就直接导入
2.如果没有,再搜索系统目录

在开发时,给文件起名,不要和系统的模块文件 重名

Python 中每一个模块都有一个内置属性__file__可以 查看模块完整路径

示例
在这里插入图片描述
注意:如果当前目录下,存在一个 random.py 的文件,程序就无法正常执行力!
这个时候,Python 的解释器会 加载当前目录 下的 random.py 而不会加载 系统的 random 模块

(4)原则——每一个文件都应该是可以被导入的

一个 独立的 Python 文件 就是一个 模块
在导入文件时,文件中所有没有任何缩进的代码都会被执行一遍!

实际开发场景
在实际开发中,每一个模块都是独立开发的,大多都有专人负责
开发人员通常会在模块下方 增加一些测试代码
  仅在模块内使用,而被导入到其他文件中不需要执行

__name__属性
__name__属性可以做到,测试模块的代码 只在测试情况下被运行,而在 被导入时不会被执行!

__name__是 Python 的一个内置属性,记录着一个字符串

如果 是被其他文件导入的,__name__就是模块名

如果是当前执行的程序__name__是__main__

在很多 Python 文件中都会看到以下格式的代码:

在这里插入图片描述

02 包(Package)

概念

是一个 包含多个模块特殊目录
目录下有一个特殊的文件__init__.py
包名的 命名方式 和变量名一致,小写字母 + _

好处

使用 import 包名 可以一次性导入 所有的模块

案例演练

1.新建一个 hm_message 的包
2.在目录下,新建两个文件 send_message 和 receive_message
3.在 send_message 文件中定义一个 send 函数
4.在 receive_message 文件中定义一个 receive 函数
5.在外部直接导入 hm_message 的包
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

03 发布模块(知道)

如果希望自己开发的模块,分享给其他人,可以按照以下步骤操作

(1)制作发布压缩包步骤

1)创建 setup.py

在这里插入图片描述

2)构建模块

在这里插入图片描述

3)生成发布压缩包

在这里插入图片描述
注意:要制作哪个版本的模块,就使用哪个版本的解释器执行!

(2)安装模块

在这里插入图片描述
卸载模块
直接从安装目录下,把安装模块的 目录 删除就可以
在这里插入图片描述

(3)pip 安装第三方模块

第三方模块 通常是指由 知名的第三方团队 开发的 并且被 程序员广泛使用 的 Python 包/模块
  例如 pygame 就是一套非常成熟的 游戏开发模块
pip 是一个现代的,通用的 Python 包管理工具
提供了对 Python 包的查找、下载、安装、卸载等功能

安装和卸载命令如下:
在这里插入图片描述
在 Mac 下安装 iPython
在这里插入图片描述
在 Linux 下安装 iPython
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值