包\常用模块

区分py文件的两种用途

py有两种用途 :一种是直接运行 另一种是当做模块被导入使用

_ _ main _ _判断是执行文件 还是被导入使用的模块

print(__name__)
-》	__main__		当右键运行的时候是 __ main__   当作执行文件直接运行的时候返回结果是 __main__
当被导入模块使用时候  返回结果是模块名
# if __name__ == '__main__': 快捷用法pycharm输入个main自动补全

包的介绍

包就是一个含有 _ init _.py文件的文件夹,文件夹内可以组织子模块或子包

创建包的目的不是为了运行,而是被导入使用,记住,包知识模块的一种形式而已包的本质就是一个模块

包的使用

包属于模块的一种,因而包以及包内的模块均是用来被导入使用的,首次导入包(如import pool)同样会做三件事:

1、执行包下的__ init __.py文件

2、产生一个新的名称空间用于存放 __ init __.py执行过程中产生的名字

3、在当前执行文件所在的名称空间中得到一个名字pool,该名字指向 __ init __.py的名称空间,例如pool.xxx 和pool.yyy中的xxx和yyy都是来自于pool下的 _ _init _ _.py,也就是说导入包时并不会导入包下所有的子模块和子包

包内的模块通常是在包下 _ _init __.py中导入了该模块 使用该模块是通过 _ init_调用

导入包与_ init _.py

1、导包就是导入包下的__ init __.py文件

2、包内部的导入就是使用相对导入,相对导入也只能在包内使用,而且...取上一级不能出包

3、使用语句中的点代表的是访问属性

m.n.x------>向m要n,向n要x

导入语句中的点代表的是路径分隔符

import a.b.c -->a/b/c

所以导入语句中点的左边必须是一个包

强调

1.关于包相关的导入语句也分为import和from ... import ...两种,但是无论哪种,无论在什么位置,在导入时都必须遵循一个原则:凡是在导入时带点的,点的左边都必须是一个包,否则非法。可以带有一连串的点,如import 顶级包.子包.子模块,但都必须遵循这个原则。但对于导入后,在使用时就没有这种限制了,点的左边可以是包,模块,函数,类(它们都可以用点的方式调用自己的属性)。

2、包A和包B下有同名模块也不会冲突,如A.a与B.a来自俩个命名空间

3、import导入文件时,产生名称空间中的名字来源于文件,import 包,产生的名称空间的名字同样来源于文件,即包下的__init__.py,导入包本质就是在导入该文件

绝对导入和相对导入

针对包内的模块之间互相导入,导入的方式有两种

1、绝对导入:以顶级包为起始

#pool下的__init__.py
from pool import versions

2、相对导入:.代表当前文件所在的目录,..代表当前目录的上一级目录,依此类推

#pool下的__init__.py
from . import versions

from包import*

在使用包时同样支持from pool.futures import * ,毫无疑问代表的是futures下__init__.py中所有的名字,通用是用变量__all__来控制代表的意思

#futures下的__init__.py
__all__=['process','thread']

最后说明一点,包内部的目录结构通常是包的开发者为了方便自己管理和维护代码而创建的,这种目录结构对包的使用者往往是无用的,此时通过操作__init__.py可以“隐藏”包内部的目录结构,降低使用难度,比如想要让使用者直接使用

import pool

pool.check()
pool.ProcessPoolExecutor(3)
pool.ThreadPoolExecutor(3)

需要操作pool下的__init__.py

from .versions import check
from .futures.process import ProcessPoolExecutor
from .futures.thread import ThreadPoolExecutor

常用模块

日志模块

logging

logger对象-》产生不同级别的日志 分类哪一种业务

handler对象-》控制日志输入的地方 可以输入到文件,也可以输入到屏幕上

formatter对象-》控制日志格式

image-20210105190318870

日志级别
CRITICAL = 50     #FATAL = CRITICAL 崩了  危机
ERROR = 40          错误
WARNING = 30     #WARN = WARNING  危险提示  警示
INFO = 20       信息 情报软件常规记录
DEBUG = 10          调试代码时候  正常运行不需要运行
NOTSET = 0         #不设置

具体使用方法:

https://www.cnblogs.com/linhaifeng/articles/6384466.html#_label12

posted @ 2021-01-05 19:17  williamgess  阅读(86)  评论(0编辑  收藏  举报