zoukankan      html  css  js  c++  java
  • 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
  • 相关阅读:
    java学习笔记
    androd Sdk manager配置
    50ms延时程序
    89c51中断入口地址表
    打印杨辉三角--队列的应用
    栈的应用--括号匹配
    哈夫曼编码---数据压缩
    PS转手绘
    数据结构学习思路
    第三届蓝桥杯省赛---第39级台阶
  • 原文地址:https://www.cnblogs.com/AbeoHu/p/5796567.html
Copyright © 2011-2022 走看看