常用内置模块
一、time模块
在python中,时间分为3种
1.时间戳: timestamp,从1970年1月1日到现在的秒数, 主要用于计算两个时间的差
2.localtime: 本地时间 表示的是计算机当前所在的位置
3.UTC:世界协调时间


import time
# 时间戳,以秒做单位
print(time.time())
# localtime 结构化时间
print(time.localtime())
# UTC时间
print(time.gmtime())
# 格式化时间
print(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime()))
# 时间戳--->结构化
print(time.localtime(time.time()))
# 结构化--->时间戳
print(time.mktime(time.localtime()))
time.sleep(5)
print('weekup')
二、datetime模块
1、python实现的一个时间处理模块,time用起来不太方便, 所以就有了datetime
2、优点:datetime相比time,更灵活
3、timedelta表示时间差
两个时间差可以加减乘除
时间差和datetime 可以加减


# 单独获取某个年月日
d1 = datetime.datetime.now()
print(d1)
print(d1.year)
print(d1.hour)
# 设定时间点
d2 = datetime.datetime(2008, 11, 15, 12, 33, 47)
print(d2)
# 计算两个时间的差
print(d1 - d2)
# 替换指定时间
print(d1.replace(year=2017))
# 表示时间差
print(datetime.timedelta(days=5))
# 时间差与datetime.datetime相加
print(d1 + datetime.timedelta(days=5))
print(d1 + datetime.timedelta(weeks=3))
三、random模块
random() 随机产生一个大于等于0且小于1的小数
randint(a,b) 随机产生一个在a与b之间的整数,包括a和b
randrange(a,b) 随机产生一个大于等于a,且小于b的数
choice([1,2,32,3,2,"哈哈"]) 随机选1个
sample([1,"a",["c","d"]],2) 随机选指定个数
uniform(1,3) 随机产生一个大于1小于3的小数
shuffle(列表) 打乱顺序


import random
# 随机生成 0 <= m < 1的数
print(random.random())
# 随机生成整数 包含头、尾
print(random.randint(1, 5))
# 随机选择一个
print(random.choice([1, 2, 3, 4]))
# 随机取3个
print(random.sample([1, 2, 'aa', [1, 2, 3]], 3))
# 随机产生一个大于1小于3的小数
print(random.uniform(1, 2))
# 打乱列表顺序
l = [1, 2, 's', 'ww', [1, 2], (1, 2, 3)]
random.shuffle(l)
print(l)
随机产生一个包含字母数字的9位验证码


def random_word(n):
for i in range(n):
res = str(random.randint(0, 9))
res2 = chr(random.randint(67, 90))
choice = random.choice([res, res2])
print(choice, end='')
random_word(9)
四、sys模块
该模块与系统相关,一般用于设计脚本程序
sys.argv 命令行参数List,第一个元素是程序本身路径,获取cmd输入的参数
sys.exit(n) 退出程序,正常退出时exit(0)
sys.version 获取Python解释程序的版本信息
sys.path 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值
sys.platform 返回操作系统平台名称


import sys
# 第一个元素是程序本身路径
print(sys.argv)
# 返回模块的搜索路径
print(sys.path)
# 退出程序
sys.exit(0)
打印进度条


def progress(percent, width):
percent = percent if percent <= 1 else 1
text = '[%%-%ds]' % (width) # text = '[%-20s]'
text = text % ('*' * int(percent * width))
text = text + '%s%%'
text = text % (percent * 100)
print('\r%s' % text, end='')
import time
import random
cur_filsize = 0
while True:
time.sleep(0.5)
file_size = 10240
cur_filsize += random.random()*100
progress(cur_filsize / file_size, 50)
if cur_filsize >= file_size:
print()
print("finish")
break


import sys
import time
def progress(percent,width=50):
if percent >= 1:
percent=1
show_str=('[%%-%ds]' %width) %(int(width*percent)*'#')
print('\r%s %d%%' %(show_str,int(100*percent)),file=sys.stdout,flush=True,end='')
data_size=1025
recv_size=0
while recv_size < data_size:
time.sleep(0.1) #模拟数据的传输延迟
recv_size+=1024 #每次收1024
percent=recv_size/data_size #接收的比例
progress(percent,width=70) #进度条的宽度70
五、os模块
该模块与操作系统相关,是围绕文件和目录的操作
os.remove() 删除一个文件
os.rename("oldname","newname") 重命名文件/目录
os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径
os.chdir("dirname") 改变当前脚本工作目录;相当于shell下cd
os.curdir 返回当前目录: ('.')
os.pardir 获取当前目录的父目录字符串名:('..')
os.makedirs('dirname1/dirname2') 可生成多层递归目录
os.removedirs('dirname1') 若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推
os.mkdir('dirname') 生成单级目录;相当于shell中mkdir dirname
os.rmdir('dirname') 删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname
os.listdir('dirname') 列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印
os.stat('path/filename') 获取文件/目录信息
os.sep 输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/"
os.linesep 输出当前平台使用的行终止符,win下为"\t\n",Linux下为"\n"
os.pathsep 输出用于分割文件路径的字符串 win下为;,Linux下为:
os.name 输出字符串指示当前使用平台。win->'nt'; Linux->'posix'
os.system("bash command") 运行shell命令,直接显示
os.environ 获取系统环境变量
os.path.abspath(path) 返回path规范化的绝对路径
os.path.split(path) 将path分割成目录和文件名二元组返回
os.path.dirname(path) 返回path的目录。其实就是os.path.split(path)的第一个元素
os.path.basename(path) 返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素
os.path.exists(path) 如果path存在,返回True;如果path不存在,返回False
os.path.isabs(path) 如果path是绝对路径,返回True
os.path.isfile(path) 如果path是一个存在的文件,返回True。否则返回False
os.path.isdir(path) 如果path是一个存在的目录,则返回True。否则返回False
os.path.join(path1[, path2[, ...]]) 将多个路径组合后返回,第一个绝对路径之前的参数将被忽略
os.path.getatime(path) 返回path所指向的文件或者目录的最后存取时间
os.path.getmtime(path) 返回path所指向的文件或者目录的最后修改时间
os.path.getsize(path) 返回path的大小
六、shutil模块
该模块用于简化文件的高级操作
主要是:复制,移动,删除,压缩文件
1、复制文件
copyfileobj(fsrc, fdst, length=16*1024)
1 import shutil
2 shutil.copyfileobj(open("a.txt","r",encoding="utf8"),open("b.txt","w",encoding="utf-8"),length=1024)
2、压缩文件
利用shutil来创建压缩文件,仅支持tar和zip格式,内部调用zipFile,tarFile模块实现
1 import shutil
2 shutil.make_archive("test","zip",root_dir="D:\脱产三期视频\Day17\代码")
解压文件


import zipfile,tarfile
# 解压zip
z = zipfile.ZipFile(r"D:\脱产三期视频\Day17\test.zip")
z.extractall()
z.close()
# 解压tar
t = tarfile.open(r"D:\脱产三期视频\Day17\test.tar")
t.extractall()
t.close()
七、pickle模块
1、作用于序列化
所谓序列化就是将内存中的数据持久化到硬盘
2、pickle产生的数据 只能由python读取 (跨平台性差)
3、示例


import pickle
dic={'name':'alvin','age':23,'sex':'male'}
print(type(dic))#<class 'dict'>
j=pickle.dumps(dic)
print(type(j))#<class 'bytes'>
f=open('序列化对象_pickle','wb')#注意是w是写入str,wb是写入bytes,j是'bytes'
f.write(j) #-------------------等价于pickle.dump(dic,f)
f.close()
#-------------------------反序列化
import pickle
f=open('序列化对象_pickle','rb')
data=pickle.loads(f.read())# 等价于data=pickle.load(f)
print(data['age'])
八、json模块
1、pickle产生的数据,只能由python读取(跨平台性差),因此json随之产生
2、json 全称 JavaScrip Object Notation,js的对象表示法
用于处理json格式数据的模块,(数据以什么格式存进去,取出来还是原来的格式)
3、json格式标准
json是一种通用的数据交换格式 目前主流的语言都能够轻松解析
注意: 在使用json格式的时候,数据类型必须按照要求来写,并且不支持python中的元组,True/Flase,'', ''',None
能存储的有:str,int,float,dic,list,bool
4、常用方法
序列化
dump 处理文件
dumps 处理字符串
反序列化
load 处理文件
loads 处理字符串
5、示例
import json
users = {'name':"音乐会","age":20,"hobbies":("music","movies")}
# 序列化
print(json.dumps(users))
json.dump(users,open("users.json","wt",encoding="utf-8"))
# json的反序列化
jsonstr = json.load(open("users.json","r",encoding="utf-8"))
print(jsonstr)
来源:oschina
链接:https://my.oschina.net/u/4394044/blog/3872658