Python 模块总结

模块(module)

模块化,模块化指将一个完整的程序分解为一个一个小的模块
通过将模块组合,来搭建出一个完整的程序
不采用模块化,统一将所有的代码编写到一个文件中
采用模块化,将程序分别编写到多个文件中
模块化的有点:
① 方便开发
② 方便维护
③ 模块可以复用!

在Python中一个py文件就是一个模块,要想创建模块,实际上就是创建一个python文件
注意:模块名要符号标识符的规范

在一个模块中引入外部模块
① import 模块名 (模块名,就是python文件的名字,注意不要py)
② import 模块名 as 模块别名

  • 可以引入同一个模块多次,但是模块的实例只会创建一个
  • import可以在程序的任意位置调用,但是一般情况下,import语句都会统一写在程序的开头
  • 在每一个模块内部都有一个__name__属性,通过这个属性可以获取到模块的名字
  • __name__属性值为 __main__的模块是主模块,一个程序中只会有一个主模块
    主模块就是我们直接通过 python 执行的模块

下面是一个使用 python 标准库中模块的例子。

import sys
 
print('命令行参数如下:')
for i in sys.argv:
   print(i)
 
print('\n\nPython 路径为:', sys.path, '\n')
  • 1、import sys 引入 python 标准库中的 sys.py 模块;这是引入某一模块的方法。
  • 2、sys.argv 是一个包含命令行参数的列表。
  • 3、sys.path 包含了一个 Python 解释器自动查找所需模块的路径的列表。

创建test_module.py文件,代码如下:

print('我是test_module模块')
print(__name__)

引入外部模块

import test_module as test

# print(test.__name__)
print(__name__)

输出结果:

我是test_module模块
test_module
__main__

创建m.py文件,代码如下:

# 可以在模块中定义变量,在模块中定义的变量,在引入模块后,就可以直接使用了
a = 10
b = 20

# 添加了_的变量,只能在模块内部访问,在通过import * 引入时,不会引入_开头的变量
_c = 30

# 可以在模块中定义函数,同样可以通过模块访问到
def test():
    print('test')

def test2():
    print('test2')

# 也可以定义类    
class Person:
    def __init__(self):
        self.name = '孙悟空'

# 编写测试代码,这部分代码,只要当当前文件作为主模块的时候才需要执行
#   而当模块被其他模块引入时,不需要执行的,此时我们就必须要检查当前模块是否是主模块  
if __name__ == '__main__':
    test()
    test2()
    p = Person()
    print(p.name)

访问模块中的内容

import m

# 访问模块中的变量:模块名.变量名
print(m.a , m.b)    # 10 20

m.test2()   # test2

p = m.Person()

print(p.name)   # 孙悟空

也可以只引入模块中的部分内容
语法 from 模块名 import 变量,变量…
from m import * # 引入到模块中所有内容,一般不会使用

from m import Person
from m import test
from m import Person,test

def test2():
    print('这是主模块中的test2')

p1 = Person()   
print(p1)   # <m.Person object at 0x0000016F72124080>
test()  # test
test2() # 这是主模块中的test2

也可以为引入的变量使用别名
语法:from 模块名 import 变量 as 别名

from m import test2 as new_test2

def test2():
    print('这是主模块中的test2')

test2() # 这是主模块中的test2
new_test2() # test2

添加了_的变量,只能在模块内部访问,在通过import * 引入时,不会引入_开头的变量

from m import *
print(_c)
发生异常: NameError
name '_c' is not defined

包 Package

包也是一个模块
当我们模块中代码过多时,或者一个模块需要被分解为多个模块时,这时就需要使用到包
普通的模块就是一个py文件,而包是一个文件夹
包中必须要有一个 __init__.py 这个文件,这个文件中可以包含有包中的主要内容

创建一个hello包

  • ①创建一个hello文件夹
  • ②在hello文件夹里创建一个__init__.py文件(必须要包含__init__.py文件)
  • 创建一个a.py文件
  • 创建一个b.py文件

__init__.py文件中的代码:

def test():
    print('test')

a.py中代码:

c = 30

b.py中代码:

d=40

导入hello包

from hello import a , b

print(a.c)  # 30
print(b.d)  # 40

__pycache__ 是模块的缓存文件
py代码在执行前,需要被解析器先转换为机器码,然后再执行
所以我们在使用模块(包)时,也需要将模块的代码先转换为机器码然后再交由计算机执行
而为了提高程序运行的性能,python会在编译过一次以后,将代码保存到一个缓存文件中
这样在下次加载这个模块(包)时,就可以不再重新编译而是直接加载缓存中编译好的代码即可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值