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)
View Code

 

posted @ 2016-08-25 22:29  AbeoHu  阅读(163)  评论(0编辑  收藏  举报