1.定义:
模块:用来从逻辑上组织python代码(变量,函数,逻辑:实现一个功能),本质就是.py结尾的python文件(文件名:test.py。)
包:用来从逻辑上组织模块的,本质就是一个目录,(必须带有一个__init__.py文件)
2.导入方法
在同级目录下
import module_name #module_name模块名
import module_name1,module_name2
from module_alex import * #导入module_alex 下的所有代码,不建议使用
from module_alex import logger as logger_alex #起别名
from module_alex import name #导入module_alex模块下的name变量
导入包同级目录
import package_test
import sys.os
a = so.path.dirname(os.path.dirname(os.path.abspath(__file__)))#搜索路径
sys.path.append(a)#添加环境变量
3.import本质(路径搜索和搜索路径)
导入模块的本质就是把python文件解释一遍
导入包的本质就是执行该包下的__init__.py文件
time模块与datetime模块
1 import time 2 time.time() #时间戳从1970年期到现在的时间,以秒计算 3 time.daylight #0代表没有使用夏令时 4 time.sleep(2) #睡几秒 5 6 7 时间戳转换成格式化的元组 8 time.gmtime() #标准时间UTC #时间戳转换成元组 9 time.gmtime(123123123) #可以传入参数,单位是秒 10 time.localtime() #本地时间 UTC+8 #时间戳转换成元组 11 x=time.localtiome(123123123) 12 print(x.tm_year) #输出123123123是哪一年 13 元组转换成时间戳 14 time.mktime(x) 15 元组转换成格式化的字符串 16 time.strftime("%Y-%m-%d %H:%M:%S",x) 17 格式化的字符串转换成元组 18 time.strptime("2016-8-21 14:38:50","%Y-%m-%d %H:%M:%S" 19 20 time.asctime() #默认就是当前时间 #元组装换成字符串 21 time.ctime() #默认就是当前时间 #时间戳转换成字符串 22 23 元组 24 time.localtime()
datetime模块
1 import datetime 2 print(datetime.datatime.now()) #获取当前时间 3 print(datetime.datatime.now()+datetime.timedelta(3))#timedelta()不能独立存在 用来算几天前的时间或几天后的时间 4 print(datetime.datatime.now()+datetime.timedelta(housr=3))#获取当天时间的前三个小时
random模块
1 random.random() #随机0-1之间的浮点数 2 random.randint(1,3) #随机1-3之间的整数 3 random.randrange(1,3) #随机1,2不包括3 4 random.choice("hello") #随机序列,字符串,列表 5 random.sample("hello",2)#随机循环两位 6 random.uniform(1,3) #随机循环1-3的浮点数
1 import random 2 checkcode="" 3 for i in range(4): 4 current=random.randrange(0,4) 5 if current == i: 6 tmp = chr(random.randint(65,90)) 7 else: 8 tmp = random.randint(0,9) 9 checkcode+=str(tmp) 10 print(checkcode)
os模块
1 os.getcwd() #获取当前目录 2 os.chdir("E:\\a") #切换目录 3 os.chdir(r"E:\a") 4 os.curdir #当前目录 5 os.pardir #上一级目录 6 os.makedirs(r"E:\a\b\c")#递归创建目录 7 os.removedirs(r"E:\a\b\c")#递归删除空目录 8 os.mkdir #创建目录 9 os.rmdir #删除空目录 10 os.listdir #列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印 11 os.remove() #删除一个文件 12 os.rename("old","new") #重命名 13 os.stat(r"hehe") #查看文件属性 14 os.sep #输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/" 15 os.linesep #输出当前平台使用的行终止符,win下为"\t\n",Linux下为"\n" 16 os.pathsep #输出用于分割文件路径的字符串 17 os.name #输出字符串指示当前使用平台。win->'nt'; Linux->'posix' 18 os.system("bash command") #运行shell命令,直接显示 19 os.environ #获取系统环境变量 20 os.path.abspath(path) #返回path规范化的绝对路径 21 os.path.split(path) #将path分割成目录和文件名二元组返回 22 os.path.dirname(path) #返回path的目录。其实就是os.path.split(path)的第一个元素 23 os.path.basename(path) #返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素 24 os.path.exists(path) #如果path存在,返回True;如果path不存在,返回False 25 os.path.isabs(path) #如果path是绝对路径,返回True 26 os.path.isfile(path) #如果path是一个存在的文件,返回True。否则返回False 27 os.path.isdir(path) #如果path是一个存在的目录,则返回True。否则返回False 28 os.path.join(path1[, path2[, ...]]) #将多个路径组合后返回,第一个绝对路径之前的参数将被忽略 29 os.path.getatime(path) #返回path所指向的文件或者目录的最后存取时间 30 os.path.getmtime(path) #返回path所指向的文件或者目录的最后修改时间
sys模块
1 sys.argv 命令行参数List,第一个元素是程序本身路径 2 sys.exit(n) 退出程序,正常退出时exit(0) 3 sys.version 获取Python解释程序的版本信息 4 sys.maxint 最大的Int值 5 sys.path 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值 6 sys.platform 返回操作系统平台名称 7 sys.stdout.write('please:') 8 val = sys.stdin.readline()[:-1]
shutil模块
1 shutil.copyfile("本节笔记","本节笔记3") #复制文件 2 shutil.copystat("本节笔记","笔记4") #复制权限 3 shutil.copytree("test4","new_test4")#递归复制目录 4 shutil.rmtree("new_test4") #递归删除目录 5 打包压缩 6 shutil.make_archive("shutil_archive_test","zip","E:\a")
1 import zipfile 2 z = zipfile.ZipFile("day5.zip","w") #默认是读 3 z.write("p_test.py") 4 print("-----") 5 z.write("笔记2") 6 z.close()
1 z = zipfile.ZipFile("day5.zip",'r') 2 z.extractall() 3 z.close()
hashlib模块
用于加密相关的操作,3.x里代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 算法
1 import hashlib 2 3 m = hashlib.md5() 4 m.update(b"Hello") 5 m.update(b"It's me") 6 print(m.digest()) 7 m.update(b"It's been a long time since last time we ...") 8 9 print(m.digest()) #2进制格式hash 10 print(len(m.hexdigest())) #16进制格式hash
1 import hmac 2 h = hmac.new(b"abcde","天王盖地虎".encode(encoding="utf-8")) 3 print(h.digest()) #十进制 4 print(h.hexdigest()) #十六进制
re模块
常用正则表达式符号
'.' 默认匹配除\n之外的任意一个字符,若指定flag DOTALL,则匹配任意字符,包括换行
'^' 匹配字符开头,若指定flags MULTILINE,这种也可以匹配上(r"^a","\nabc\neee",flags=re.MULTILINE)
'$' 匹配字符结尾,或e.search("foo$","bfoo\nsdfsf",flags=re.MULTILINE).group()也可以
'*' 匹配*号前的字符0次或多次,re.findall("ab*","cabb3abcbbac") 结果为['abb', 'ab', 'a']
'+' 匹配前一个字符1次或多次,re.findall("ab+","ab+cd+abb+bba") 结果['ab', 'abb']
'?' 匹配前一个字符1次或0次
'{m}' 匹配前一个字符m次
'{n,m}' 匹配前一个字符n到m次,re.findall("ab{1,3}","abb abc abbcbbb") 结果'abb', 'ab', 'abb']
'|' 匹配|左或|右的字符,re.search("abc|ABC","ABCBabcCD").group() 结果'ABC'
'(...)' 分组匹配,re.search("(abc){2}a(123|456)c", "abcabca456c").group() 结果 abcabca456c
'\A' 只从字符开头匹配,re.search("\Aabc","alexabc") 是匹配不到的
'\Z' 匹配字符结尾,同$
'\d' 匹配数字0-9
'\D' 匹配非数字
'\w' 匹配[A-Za-z0-9]
'\W' 匹配非[A-Za-z0-9]
's' 匹配空白字符、\t、\n、\r , re.search("\s+","ab\tc1\n3").group() 结果 '\t'
'(?P<name>...)' 分组匹配 re.search("(?P<province>[0-9]{4})(?P<city>[0-9]{2})(?P<birthday>[0-9]{4})","371481199306143242").groupdict("city") 结果{'province': '3714', 'city': '81', 'birthday': '1993'}
最常用的匹配语法
re.match 从头开始匹配
re.search 匹配包含
re.findall 把所有匹配到的字符放到以列表中的元素返回
re.splitall 以匹配到的字符当做列表分隔符
re.sub 匹配字符并替换