python导入模块的三种方法(Python -- 模块基础,循环导入)python基础 / python模块导入基础...

wufei123 发布于 2024-06-30 阅读(8)

模块的基础模块是一系列功能的集合体,而函数是某一个功能的集合体,因此模块可以看成是一堆函数的集合体一个py文件内部就可以放一堆函数,因此一个py文件就可以看成一个模块如果这个py文件的文件名为module.py,模块名则是module。

从普通的面条版到函数版,其实是在做:封装代码,一个函数差不多2-40行代码让不同功能的代码独立开来为什么要用模块?可以极大地提升开发效率自定义模块,文件版Python中叫做模块,模块可以放多个函数,然后把很多各函数分成多个文件,一个模块具有大的功能。

模块的形式:自定义模块第三方库,需要自己下载,如requests内置模块,直接用就行了,如time文件夹板,在pyton中就叫做包如何用模块一般我们使用import和from...import...导入模块

import与from...import模块就是拿来用的,简化操作,我们不需要再重复开发相同的功能,拿来用就可以了import time打开time文件把time文件内的内容读入python解释器的内存,然后把文件内的名字放入特定的模块time的名称空间time.sleep(0)

使用‘time .sleep(0)的时候,会去time模块的名称空间内部寻找time的方法导入使用‘time.sleep(0)就可以了优点:time里面有的就全拿到了缺点:占用内存比较大,必须得通过time出来

from...import...from time import sleep打开time文件、把time文件内的内容读入Python解释器的内存,然后把文件内的名字放入特定的模块time的名称空间把sleep单独拿出来放入import与from...import.py的名称空间去了

sleep(0)导入使用‘sleep(0)’就可以了优点:直接使用sleep(0)就可以了,不用加前缀,代码更精简缺点:只能拿到sleep,如果该文件定义了sleep参数,容易与当前执行文件中名称空间中的名字冲突

总结相同点:两者都会执行模块对应的文件,两者都会产生模块的名称空间两者调用功能时,需要跑到定义时寻找作用域关系,与调用位置无关不同点import需要加前缀;from...import...不需要加前缀循环导入问题解决

例如: 我现在有m1和m2两个文件,然后m1需要找到m2的y;m2需要找到m1 的x,但是由于代码至上而下运行,m1中的x还没有生成;m2中的y也没有生成, 所以m1找不到m2的y;m2找不到m1的x,就造成了一个死循环 解决方案一: 导入之前让变量提前生成,但是又发现了一个新问题,会执行两次

printprint(__name__) 在当前执行文件内打印它为__main__,在导入时打印它为文件名 解决方案二: 把需要导入的名字y封装到函数体内部名字的执行顺序:内置--》全局--》局部,调用函数的时候才会用到y,调用函数之前,全局变量x已经生成了,m2能找到x,y就能够生成, m1就能找到y,问题就解决了。

模块的搜索路径以后写项目会分成运行文件和模块文件,运行文件需要寻找这些模块的时候,是有顺序的导入模块时查找模块的顺序是:先从内存中已经导入的模块中寻找内置的模块环境变量中找1.内存中有的: 运行过的

import time import m1 # 在文件内找到的,保存在内存里了 # 删除了m1 time.sleep(10) # m1还是在内存里的 import m1 # 现在内存里找的

2.内置模块 import time 3.环境变量中(自定义) import sys print(sys.path)搜索路径以执行文件为准Python文件的两种用途以当做模块导入,模块文件当做运行文件运行,运行文件

编写好的一个python文件可以有两种用途:脚本,一个文件就是整个程序,用来被执行模块,文件中存放着一堆功能,用来被导入使用

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

河南中青旅行社综合资讯 奇遇综合资讯 盛世蓟州综合资讯 综合资讯 游戏百科综合资讯 新闻15565