1、模块介绍
1.1、定义:模块:用来从逻辑上组织python代码(变量、函数、类、逻辑:实现有个功能)
本质就是.py结尾的python文件(文件名:test.py,对应的模块名是test)
包:是用来从逻辑上组织模块的,本质就是一个目录或文件夹(必须带有__init__.py的文件)
1.2、导入方法:import moudle_name1,moudle_name2
from moudle_name import *
#不提倡这种导入方法,等于把moudle_name中的代码在当前文件执行一次,容易冲突
from moudle_name import name1,name2,name3
from moudle_name import logger as logger_ls
用from也可以,导入某个特定方法,另起别名,就可以调用不怕冲突了
1.2.2、导入包的本质:解释执行这个包下的__init__.py文件
想要调用导入的包下的别的名字的文件(test1.py)
可以在修改那个包下的 __init__.py 文件,将 from . import test1 写入
就能在当前的文件里
1.3、调用:用import moudle_name1,moudle_name2这种方法调用导入
调用的时候直接 moudle_name1. 调用才可以
1.4、import的本质:将moudle_name中的代码解释一遍,赋值给moudle_name这个变量,
moudle_name.name()才能调用
from moudle_name import name 本质:只把moudle_name模块当中的name在当前文及中执行了一遍,
直接name()就能执行了
os.path.dirname() #获取当前(文件或目录)的目录名,想返回前两层,就来两次这个方法
__file__ #当前文件名
os.path.abspath(__file__) #获取这个文件的绝对路径
1.5、导入优化
在当前文件的同级目录下定义一个module_test.py模块,内有test()函数,print("in the module_test")
import module_test
def logger():
module_test.test() #调用module_test模块中的test()方法
print("in the logger")
def search():
module_test.test() #调用module_test模块中的test()方法
print("in the search")
logger()
search()
--->
in the module_test
in the logger
in the module_test
in the search
######如果多次调用module_test模块中的test()方法,在寻找module_test模块的过程会浪费时间,因为每一次调用
都会寻找一次module_test模块这个模块,改怎么优化呢???
如下:
from module_test import test #开头直接写死,不让他寻找,直接告诉他在哪个地方
def logger():
test()
print("in the logger")
def search():
test()
print("in the search")
logger()
search() #输出一样
2、模块的分类
2.1、标准库,如:os、sys、time
2.2、开源模块:第三方模块,别人写的模块上传到网上,自己下载下来可以直接用
2.3、自定义模块
3、常用内置模块:
1、time & datetime
2、random
3、os
4、sys
5、shutil
6、json & picle
7、shelve
8、xml处理
9、yaml处理
10、configparser
11、hashlib
12、subprocess
13、logging
14、re正则表达式
1、time & datetime 模块
在python里,常用几种格式来表示时间:
1)时间戳:从当前时间减去1970年1月1日0分0秒,这个时间间隔的秒数
2)格式化的时间字符串,如:2019-09-25 16:12:54
3)元组(struct_time)共9个元素
转载:https://blog.csdn.net/a17853481576/article/details/101352347
查看评论