模块概念
- py文件就是模块
- 导入模块时 是把模块从头到尾执行一遍
- __name__属性用来识别是模块还是程序,在模块中添加 if name == “main“可以方便的测试模块
- 包导入路径
- init.py 告诉Python这个文件夹是包,初始化包,导入包必须先运行init
- all = [] 设置星号的引用的模块
语法
import 模块名
from 模块名 import 功能名
import 包名.模块名
from 包名 import * # 必须在__init__.py文件中添加__all__ = [],控制允许导入的模块列表。
解析器路径
当导入一个模块,Python解析器对模块位置的搜索顺序是:
当前目录
如果不在当前目录,Python则搜索在shell变量PYTHONPATH下的每个目录。
如果都找不到,Python会察看默认路径。UNIX下,默认路径一般为/usr/local/lib/python/
模块搜索路径存储在system模块的sys.path变量中。变量里包含当前目录,PYTHONPATH和由安装过程决定的默认目录。
import sys
sys.path # 工作路径,列出的目录里依次查找要导入的模块文件
sys.path.append('/home/claroja/xxx')
sys.path.insert(0, '/home/claroja/xxx') # 添加工作路径
__all__
如果一个模块文件中有__all__变量,当使用from xxx import *导入时,只能导入这个列表中的元素。
__all__ = ['testA']
def testA():
print('testA')
def testB():
print('testB')
from my_module1 import *
testA()
testB() #无法导入
_name_和_main_
当一个.py文件被执行时它的_name_属性为_main_,否则不为_main_,所以我们可以利用这一点对模块进行调试.另外要注意的是导入模块时,把模块从头到尾执行一遍.
if name == “main”:
init
init.py 告诉python这个文件夹是包,初始化包,导入包必须先运行__init__
all
控制着 from 包名 import *时导入的模块
#基本概念
bs4库导入实例
直接导入package包
import bs4
# 需要包名加方法类方法名
bs4.BeautifulSoup(Tag)
导入package包的方法
from bs4 import BeautifuleSoup
# 只需要方法名
BeautifulSoup(Tag)
pycache缓存文件夹是用来管理二进制编译后的.py文件(每次导入包之后,都会自动生成它的编译文件).后缀.pyc的意思是cpython是用C语言写的解析器
总结
层级关系
:是包的入口
和
:这两个都可以看成是文件的路径
而中的
方法和
类,才是我们需要导入的最终,比如:
from bs4 import BeautifuleSoup
# 只需要方法名
BeautifulSoup(Tag)
如果只导入到和
这一层,则需要把方法的路径名称写上,比如:
import bs4
# 需要包名加方法类方法名
bs4.BeautifulSoup(Tag)