模块import的调用规则

首先:函数的意义是什么?

当然,函数的使用是为了避免重复的代码利用,而模块也是一样模块的实际内容和本质也是提供一个 .py 的文件,通过引入模块文件来使用文件内部的函数或者功能等。

print(time)

当我们单独打印一个time 时,会发生错误,因为此时文件内部的time没有被定义。

python 在安装时就已经内部加载了一些模块,time模块就是其中之一,我们需要引入time从而实现time模块的功能。

import time

print(time)

打印的结果如下,表明module time已经被加载进去了 

<module 'time' (built-in)>

接下来我们就可以使用time模块中的各种功能,在pycharm中模块后加 . 便可以展示出模块的功能。  

那么,模块有哪些分类呢?

我们一般接触的模块一共有三类:分别是  1.python 标准库模块  2.第三方定义模块 3.自定义应用程序模块。第三方定义的模块可以使用python标准库中的 pip 在命令行进行操作然后加载进我们所使用python的环境中。在加载模块以前,我们还必需搞清楚一个概念,就是文件夹和package的区别是什么?

文件夹与package:

我们知道,文件夹就是常用来存放文件的一个整合,我们可以把我们需要储存的文件存放在文件夹里,可以是.txt,可以是.exe,也可以是.py。但是当我们在pycharm中建立一个package时候,文件中会自动存在一个命名为“__init__”的.py 文件,这个文件就是我们package的主文件,而文件夹与package的区别就在这里。

从模块中调用函数:

尽管我们调用了time模块,但是如果我们想使用time模块里面的功能就还需要调用time.time()或者time.sleep(),这样不是很方便,而且直接import time 模块所使用的内存量巨大,在进行大型项目的时候通常需要导入很多的库,这将使程序运行的内存巨大,导致程序崩坏。所以我们调用的方式通过如下:

from time import time
from time import sleep

from time import 调用的函数,这样可以精准的使用函数,并且不占内存,而通过上边的方式也可以将time模块里的所有函数都导入进来,代码如下:

form time import *

这样的方式同样占据了很多的内存,这里不推荐使用。

import 引入的模块的路径是什么?

我们通过在相同的包里,建立test.py文件,并且加入定义的add函数,调用试试看

__init__文件中,我们引入如下:

from test_add import add
print(add(5,6))

同时在相同的package中定义文件名为test_add.py的文件,并且加入函数:

print("this is web_test_add file" )

def add(x,y):
    print("this is from model file")
    return x+y

def sub(x,y):
    print("this is from model file")
    return x-y
this is web_test_add file
this is from model file
11

我们可以看到,我们直接导入了add函数,并且可以使用。但是我们在导入test_add.py时不仅加入了函数,还运行了print,所以我们得出,在import导入后,其内部封装是把import引入模块的所有变量都导入进入并且运行,才会有如上的结果。

总结:

我们通过import导入模块,并且通过from module import func 的形式导入模块内部的函数,或者通过from module import * 的方法导入全部的函数,而其内部的封装,就是把import导入的模块内的所有函数作为变量导入,然后执行。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值