Python中模块和包基础学习

简介: Python中模块和包基础学习

模块


Python中的模块是指一个文件,可以包含函数、类、变量和可执行代码等,并且可以被其他程序引入和使用。使用模块可以使得代码更加模块化和易于维护。


Python中的模块分为两种类型:内置模块和外部模块。内置模块是指Python自带的模块,如math、random、datetime等,可以直接使用。外部模块是指需要通过pip等工具安装的模块,如numpy、pandas等。


Python中的模块可以通过import语句引入,例如:

import math 
print(math.pi)

上述代码中,引入了math模块,并输出了pi这个变量。

引入模块

除了import语句之外,Python还提供了其他几种方式来引入模块,如from...import语句、import...as语句等。下面是一些模块操作的代码示例:


使用from...import语句引入模块中的指定变量或函数

1. from math import pi 
2. 
3. print(pi)

上述代码中,我们只引入了math模块中的pi变量,而没有引入其他内容。

使用import...as语句给模块起别名

1. import math as m 
2. 
3. print(m.pi)

上述代码中,我们使用import...as语句给math模块起了一个别名m,并输出了pi这个变量。

使用dir()函数查看模块中的所有变量和函数

1. import math 
2. 
3. print(dir(math))


上述代码中,我们使用dir()函数查看了math模块中的所有变量和函数。

使用__name__变量判断模块是被导入还是直接执行

if __name__ == '__main__': 
    print('This is the main program.') 
else: 
    print('This is a module.') 


上述代码中,我们使用__name__变量判断模块是被导入还是直接执行,如果是直接执行,则输出This is the main program.,否则输出This is a module.。


以上是一些Python模块的基本介绍和操作示例。在实际开发中,模块的使用和操作也是非常常见和重要的,熟练掌握这些知识点可以提高代码的复用性和可维护性。



在 Python 中,包(Package)是一个有层次结构的文件目录,其中包含了模块(Module)和子包(Subpackage)。包的作用是将模块组织在一起,提供更好的命名空间管理和模块复用机制。


Python 中的包需要满足以下两个条件:


1. 包目录下必须包含一个名为 __init__.py 的文件。这个文件可以是空文件,也可以包含一些 Python 代码。


2. 包目录必须在 Python 的模块搜索路径中。


下面是一个包的示例,其中 mypackage 是包的名称,__init__.py 文件是必需的。

mypackage/
 ├── __init__.py 
 ├── module1.py
 ├── module2.py
 └── subpackage/
   ├── __init__.py
   └── module3.py 


在这个示例中,mypackage 是一个包,它包含了两个模块 module1.py 和 module2.py,还包含了一个子包 subpackage,子包中包含了一个模块 module3.py。


包中的模块可以通过 import 语句来使用。例如,要使用 module1.py 中定义的函数,可以使用以下代码:

from mypackage import module1 
module1.my_function() 

如果要使用子包中的模块,可以使用以下代码:

1. from mypackage.subpackage import module3 
2. 
3. module3.my_function()


注意

在使用包时,需要注意以下几点:


1.包目录名不能和 Python 内置模块名相同,否则会导致导入内置模块时出错。


2.包名应该遵循小写字母、单词之间用下划线分隔的命名规范,这样可以提高代码的可读性。


3.在 __init__.py 文件中可以定义包级别的变量和函数,这些变量和函数可以被包中的模块共享。


4.在包的 __init__.py 文件中可以使用 __all__ 变量来指定包的公共接口,只有 __all__ 中列出的模块和变量才会被导入到 from mypackage import * 语句中。


示例


下面是一个包的示例,包含了一个 __init__.py 文件和一个模块 module1.py:

1. mypackage/
2.  ├── __init__.py
3.  └── module1.py


__init__.py 文件中定义了一个变量 __version__ 和一个函数 my_function():


1. __version__ = '1.0.0'
2. 
3. def my_function(): 
4. print('Hello from my_function()')

module1.py 中使用了包中的变量和函数:

from mypackage import __version__, my_function
def main():
    print(f'My package version is {__version__}')
    my_function()
if __name__ == '__main__':
    main()


相关文章
|
25天前
|
机器学习/深度学习 Python
堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能
本文深入探讨了堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能。文章详细介绍了堆叠的实现步骤,包括数据准备、基础模型训练、新训练集构建及元学习器训练,并讨论了其优缺点。
43 3
|
6天前
|
Python
Python Internet 模块
Python Internet 模块。
101 74
|
5天前
|
Python 容器
Python学习的自我理解和想法(9)
这是我在B站跟随千锋教育学习Python的第9天,主要学习了赋值、浅拷贝和深拷贝的概念及其底层逻辑。由于开学时间紧张,内容较为简略,但希望能帮助理解这些重要概念。赋值是创建引用,浅拷贝创建新容器但元素仍引用原对象,深拷贝则创建完全独立的新对象。希望对大家有所帮助,欢迎讨论。
|
24天前
|
算法 数据安全/隐私保护 开发者
马特赛特旋转算法:Python的随机模块背后的力量
马特赛特旋转算法是Python `random`模块的核心,由松本真和西村拓士于1997年提出。它基于线性反馈移位寄存器,具有超长周期和高维均匀性,适用于模拟、密码学等领域。Python中通过设置种子值初始化状态数组,经状态更新和输出提取生成随机数,代码简单高效。
104 63
|
26天前
|
测试技术 Python
手动解决Python模块和包依赖冲突的具体步骤是什么?
需要注意的是,手动解决依赖冲突可能需要一定的时间和经验,并且需要谨慎操作,避免引入新的问题。在实际操作中,还可以结合使用其他方法,如虚拟环境等,来更好地管理和解决依赖冲突😉。
|
26天前
|
持续交付 Python
如何在Python中自动解决模块和包的依赖冲突?
完全自动解决所有依赖冲突可能并不总是可行,特别是在复杂的项目中。有时候仍然需要人工干预和判断。自动解决的方法主要是提供辅助和便捷,但不能完全替代人工的分析和决策😉。
|
8天前
|
存储 索引 Python
Python学习的自我理解和想法(6)
这是我在B站千锋教育学习Python的第6天笔记,主要学习了字典的使用方法,包括字典的基本概念、访问、修改、添加、删除元素,以及获取字典信息、遍历字典和合并字典等内容。开学后时间有限,内容较为简略,敬请谅解。
|
12天前
|
存储 程序员 Python
Python学习的自我理解和想法(2)
今日学习Python第二天,重点掌握字符串操作。内容涵盖字符串介绍、切片、长度统计、子串计数、大小写转换及查找位置等。通过B站黑马程序员课程跟随老师实践,非原创代码,旨在巩固基础知识与技能。
|
11天前
|
程序员 Python
Python学习的自我理解和想法(3)
这是学习Python第三天的内容总结,主要围绕字符串操作展开,包括字符串的提取、分割、合并、替换、判断、编码及格式化输出等,通过B站黑马程序员课程跟随老师实践,非原创代码。
|
8天前
|
Python
Python学习的自我理解和想法(7)
学的是b站的课程(千锋教育),跟老师写程序,不是自创的代码! 今天是学Python的第七天,学的内容是集合。开学了,时间不多,写得不多,见谅。
下一篇
DataWorks