高级模块
一 .time与datetime模块
在Python中,通常有这几种方式来表示时间:
-
时间戳(timestamp):通常来说,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量。我们运行“type(time.time())”,返回的是float类型。
-
格式化的时间字符串(Format String)
-
结构化的时间(struct_time):struct_time元组共有9个元素共九个元素:(年,月,日,时,分,秒,一年中第几周,一年中第几天,夏令时)
1 import time
2 #--------------------------我们先以当前时间为准,让大家快速认识三种形式的时间
3 print(time.time()) # 时间戳:1487130156.419527
4 print(time.strftime("%Y-%m-%d %X")) #格式化的时间字符串:'2017-02-15 11:40:53'
5
6 print(time.localtime()) #本地时区的struct_time
7 print(time.gmtime()) #UTC时区的struct_time
1 # asctime([t]) : 把一个表示时间的元组或者struct_time表示为这种形式:'Sun Jun 20 23:21:05 1993'。
2 # 如果没有参数,将会将time.localtime()作为参数传入。
3 print(time.asctime())#Sun Sep 11 00:43:43 2016
4 # ctime([secs]) : 把一个时间戳(按秒计算的浮点数)转化为time.asctime()的形式。如果参数未给或者为
5 # None的时候,将会默认time.time()为参数。它的作用相当于time.asctime(time.localtime(secs))。
6 print(time.ctime()) # Sun Sep 11 00:46:38 2016
7 print(time.ctime(time.time())) # Sun Sep 11 00:46:38 2016
1 #--------------------------其他用法
2 # sleep(secs)
3 # 线程推迟指定的时间运行,单位为秒。
时间加减
import datetime
# print(datetime.datetime.now()) #返回 2016-08-19 12:47:03.941925
#print(datetime.date.fromtimestamp(time.time()) ) # 时间戳直接转成日期格式 2016-08-19
# print(datetime.datetime.now() )
# print(datetime.datetime.now() + datetime.timedelta(3)) #当前时间+3天
# print(datetime.datetime.now() + datetime.timedelta(-3)) #当前时间-3天
# print(datetime.datetime.now() + datetime.timedelta(hours=3)) #当前时间+3小时
# print(datetime.datetime.now() + datetime.timedelta(minutes=30)) #当前时间+30分
#
# c_time = datetime.datetime.now()
# print(c_time.replace(minute=3,hour=2)) #时间替换
二. random模块
1 import random
2
3 print(random.random())#(0,1)----float 大于0且小于1之间的小数
4
5 print(random.randint(1,3)) #[1,3] 大于等于1且小于等于3之间的整数
6
7 print(random.randrange(1,3)) #[1,3) 大于等于1且小于3之间的整数
8
9 print(random.choice([1,'23',[4,5]]))#1或者23或者[4,5]
10
11 print(random.sample([1,'23',[4,5]],2))#列表元素任意2个组合
12
13 print(random.uniform(1,3))#大于1小于3的小数,如1.927109612082716
14
15
16 item=[1,3,5,7,9]
17 random.shuffle(item) #打乱item的顺序,相当于"洗牌"
18 print(item)
生成随机验证码
import random
def make_code(n):
res=''
for i in range(n):
s1=chr(random.randint(65,90))
s2=str(random.randint(0,9))
res+=random.choice([s1,s2])
return res
print(make_code(9))
三 .os模块
os模块是与操作系统交互的一个接口
1.
os.getcwd() **获取当前工作目录,即当前python脚本工作的目录路径
**
2.
os.chdir("dirname") **改变当前脚本工作目录;相当于shell下cd**
3.
os.curdir **返回当前目录: ('.')**
4.
os.pardir **获取当前目录的父目录字符串名:('..')**
5.
os.path.isdir(path) **如果path是一个存在的目录,则返回True。否则返回False。**
6.
os.makedirs('dirname1/dirname2') **可生成多层递归目录**
7.
os.removedirs('dirname1') **若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推**
8.
os.mkdir('dirname') ** 生成单级目录;相当于shell中mkdir dirname**
9.
os.rmdir('dirname') **删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname**
10.
os.listdir('dirname') **列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印**
11.
os.remove() **删除一个文件**
12.
os.rename("oldname","newname") **重命名文件/目录**
13.
os.stat('path/filename') **获取文件/目录信息**
14.
os.sep **输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/"**
15.
os.linesep **输出当前平台使用的行终止符,win下为"\t\n",Linux下为"\n"**
16.
os.pathsep **输出用于分割文件路径的字符串 win下为;,Linux下为:**
17.
os.name **输出字符串指示当前使用平台。win->'nt'; Linux->'posix'**
18.
os.system("bash command") **运行shell命令,直接显示**
19.
os.environ **获取系统环境变量**
20.
os.path.normpath(path) **规范化路径**
>>> os.path.normpath('c://windows\\System32\\../Temp/')
'c:\\windows\\Temp'
21.
os.path.abspath(path) **返回path规范化的绝对路径**
22.
os.path.split(path) **将path分割成目录和文件名二元组返回**
23.
os.path.splitext(path) **分离文件名与扩展名;默认返回(fname,fextension)元组,可做分片操作**
>>> os.path.splitext('c:\\csv\\test.csv')
('c:\\csv\\test', '.csv')
24.
os.path.dirname(path) **返回path的目录。其实就是os.path.split(path)的第一个元素**
25
.os.path.basename(path) **返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素**
26.
os.path.exists(path) **如果path存在,返回True;如果path不存在,返回False**
27.
os.path.isabs(path) ** 如果path是绝对路径,返回True**
28.
os.path.isfile(path) **如果path是一个存在的文件,返回True。否则返回False**
29.
os.path.isdir(path) **如果path是一个存在的目录,则返回True。否则返回False**
30.
os.path.join(path1[, path2[, ...]]) **将多个路径组合后返回,第一个绝对路径之前的参数将被忽略**
31.
os.path.getatime(path) **返回path所指向的文件或者目录的最后存取时间**
32.
os.path.getsize(path) **返回path的大小(字节)**。
>>> os.path.getsize('c:\\boot.ini')
299L
33.
os.path.commonprefix(list) **返回list中,所有path共有的最长的路径。**
34.
os.path.exists(path) **如果path存在,返回True;如果path不存在,返回False。**
os路径处理
#方式一:推荐使用
import os
#具体应用
import os,sys #os.path.jion将多个路径组合后返回,第一个绝对路径之前的参数将被忽略
#os.path.normpath(path) 规范化路径
#os.path.abspath 返回path规范化的绝对路径
possible_topdir = os.path.normpath(os.path.join(
os.path.abspath(__file__),
os.pardir, #上一级
os.pardir,
os.pardir
))
sys.path.insert(0,possible_topdir)
#方式二:不推荐使用
os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
四 .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 返回操作系统平台名称
#=========知识储备==========
#进度条的效果
[# ]
[## ]
[### ]
[#### ]
#指定宽度
print('[%-15s]' %'#')
print('[%-15s]' %'##')
print('[%-15s]' %'###')
print('[%-15s]' %'####')
#打印%
print('%s%%' %(100)) #第二个%号代表取消第一个%的特殊意义
#可传参来控制宽度
print('[%%-%ds]' %50) #[%-50s]
print(('[%%-%ds]' %50) %'#')
print(('[%%-%ds]' %50) %'##')
print(('[%%-%ds]' %50) %'###')
#=========实现打印进度条函数==========
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
五 .shutil模块
高级的 文件、文件夹、压缩包 处理模块
shutil.copyfileobj(fsrc, fdst[, length])
将文件内容拷贝到另一个文件中
1 import shutil2 3 shutil.copyfileobj(open('old.xml','r'), open('new.xml', 'w'))
shutil.copyfile(src, dst)
拷贝文件
1 shutil.copyfile('f1.log', 'f2.log') #目标文件无需存在
shutil.copymode(src, dst)
仅拷贝权限。内容、组、用户均不变
1 shutil.copymode('f1.log', 'f2.log') #目标文件必须存在
shutil.copystat(src, dst)
仅拷贝状态的信息,包括:mode bits, atime, mtime, flags
1 shutil.copystat('f1.log', 'f2.log') #目标文件必须存在
shutil.copy(src, dst)
拷贝文件和权限
1 import shutil2 3 shutil.copy('f1.log', 'f2.log')
shutil.copy2(src, dst)
拷贝文件和状态信息
1 import shutil2 3 shutil.copy2('f1.log', 'f2.log')
shutil.ignore_patterns(*patterns)
shutil.copytree(src, dst, symlinks=False, ignore=None)
递归的去拷贝文件夹
import shutil shutil.copytree('folder1', 'folder2', ignore=shutil.ignore_patterns('*.pyc', 'tmp*'))
#目标目录不能存在,注意对folder2目录父级目录要有可写权限,
ignore的意思是排除
'''import shutilshutil.copytree('f1', 'f2', symlinks=True, ignore=shutil.ignore_patterns('*.pyc', 'tmp*'))
'''通常的拷贝都把软连接拷贝成硬链接,即对待软连接来说,创建新的文件
shutil.rmtree(path[, ignore_errors[, onerror]])
递归的去删除文件
1 import shutil2 3 shutil.rmtree('folder1')
shutil.move(src, dst)
递归的去移动文件,它类似mv命令,其实就是重命名。
1 import shutil2 3 shutil.move('folder1', 'folder3')
shutil.make_archive(base_name, format,...)
创建压缩包并返回文件路径,例如:zip、tar
创建压缩包并返回文件路径,例如:zip、tar
- base_name: 压缩包的文件名,也可以是压缩包的路径。只是文件名时,则保存至当前目录,否则保存至指定路径,
如 data_bak =>保存至当前路径
如:/tmp/data_bak =>保存至/tmp/ - format: 压缩包种类,“zip”, “tar”, “bztar”,“gztar”
- root_dir: 要压缩的文件夹路径(默认当前目录)
- owner: 用户,默认当前用户
- group: 组,默认当前组
- logger: 用于记录日志,通常是logging.Logger对象
1 #将 /data 下的文件打包放置当前程序目录
2 import shutil3 ret = shutil.make_archive("data_bak", 'gztar', root_dir='/data')
#将 /data下的文件打包放置 /tmp/目录
import shutil8 ret = shutil.make_archive("/tmp/data_bak", 'gztar', root_dir='/data')
shutil 对压缩包的处理是调用 ZipFile 和 TarFile 两个模块来进行的,详细:
import zipfile
# 压缩z = zipfile.ZipFile('laxi.zip', 'w')z.write('a.log')z.write('data.data')z.close()
# 解压z = zipfile.ZipFile('laxi.zip', 'r')z.extractall(path='.')z.close()
import tarfile
压缩>>>
t=tarfile.open('/tmp/egon.tar','w')>>> t.add('/test1/a.py',arcname='a.bak')>>> t.add('/test1/b.py',arcname='b.bak')>>> t.close()
解压>>>
t=tarfile.open('/tmp/egon.tar','r')>>> t.extractall('/egon')>>> t.close()

浙公网安备 33010602011771号