Python Day5
本章知识:
1.模块详解
2.正则表达式
一.模块介绍
模块分类
1 标准库
2 开源模块
3 自定义模块
1标准库(python内部模块)
time,datetime模块
time模块
time.sleep 让代码停止5秒
time.time 时间戳
>>> x = time.time() >>> >>> x/3600 408847.68797914986
time.gmtime 将时间戳转换成元组,显示出年月份日
>>> time.gmtime(a) time.struct_time(tm_year=1970, tm_mon=1, tm_mday=5, tm_hour=17, tm_min=34, tm_sec=7, tm_wday=0, tm_yday=5, tm_isdst=0)
time.localtime转换成本地时间
>> time.localtime(x)
time.struct_time(tm_year=1970, tm_mon=1, tm_mday=1, tm_hour=14, tm_min=10, tm_sec=22, tm_wday=3, tm_yday=1, tm_isdst=0)
格式化字符串
time.strftime()
time.strftime('%Y-%m-%d %H:%M:%S',x)
'2016-08-20 15:18:51'
time.strptime()将格式化的字符串转换成元组格式时间内
time.ctime接受时间戳形式转换成格式化
time.atime接受元组形式转换成格式化
datetime模块
datetime用法:
datetime.datetime.now()当前时间
datetime.datetime.now()+datetime.datetimedelta(3) 后三天
datetime.datetime.now()+datetime.datetimedelta(-3) 前三天
random模块(随机模块)
random.random 取出0-1的浮点数
import random print(random.random())
random.uniform(1-10) 取出1-10的浮点数
import random print(random.uniform(1,10))
random.shuffle 洗牌,重新排序
random模块实现生成验证码
# _author_=AbeoHu import random checkcode=''#定义空字段 for i in range(4): current=random.randrange(0,4)#随机取0-4之间的字符,做判断 if current==i: tmp=chr(random.randint(65,90))#取字母,chr代表取字幕 else: tmp=(random.randint(1,9))#取出1-9数字 checkcode+=str(tmp)#打印字符串 +=组合字符串 print(checkcode)
os模块
os模块本身和系统是有交互的
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.remove() 删除一个文件 os.rename("oldname","newname") 重命名文件/目录 os.stat('path/filename') 获取文件/目录信息 os.sep 输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/" os.linesep 输出当前平台使用的行终止符,win下为"\t\n",Linux下为"\n" os.pathsep 输出用于分割文件路径的字符串 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所指向的文件或者目录的最后修改时间
sys模块
sys.argv 命令行参数List,第一个元素是程序本身路径 sys.exit(n) 退出程序,正常退出时exit(0) sys.version 获取Python解释程序的版本信息 sys.maxint 最大的Int值 sys.path 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值 sys.platform 返回操作系统平台名称 sys.stdout.write('please:') val = sys.stdin.readline()[:-1]
shutil模块
参考http://www.cnblogs.com/wupeiqi/articles/4963027.html
json和pickle模块
用于序列化的两个模块
- json,用于字符串 和 python数据类型间进行转换
- pickle,用于python特有的类型 和 python的数据类型间进行转换
Json模块提供了四个功能:dumps、dump、loads、load
pickle模块提供了四个功能:dumps、dump、loads、load
二.正则表达式
正则表达式(匹配字符串)
re模块
match 开头 search所有只匹配第一个 findall所有都返回 咩咩咩咩咩咩咩咩咩咩咩咩咩咩咩密密麻麻
. 默认匹配除了\n之外的任意一个字符
^ 开头
$ 结尾
'.' 默认匹配除\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'
re.match 从头开始匹配
re.search 匹配包含
re.findall 把所有匹配到的字符放到以列表中的元素返回
re.splitall 以匹配到的字符当做列表分隔符
re.sub 匹配字符并替换
正则表达式用到的函数:
compile match search finddall group groups
match(起始位置查找)
search(全部位置查询)
group(显示匹配内容)
groups()
findall(都匹配出来)
import re re1=re.match('\d+','1a1sdfasfasfdasdf31234sadfsdfaf')#起始位置匹配 re2=re.search('\d+','a1sdfasfasfdasdf31234sadfsdfaf')#在整个内容去匹配 print(re1.group())#显示匹配内容 print(re2.group()) findall re3=re.findall('\d+','11111111a1sd2222222222222fasfasfdasdf31234sadfsdfaf')#只要是数字的,都匹配出来 print(re3)