zoukankan      html  css  js  c++  java
  • glob模块

    glob模块是一个文件操作相关模块,用它可以查找符合要求的文件,支持通配符操作。

    通配符 功能
    *     匹配0或多个字符
    **   匹配所有文件,目录,子目录和子目录里面的文件 (3.5版本新增)
    ?     匹配一个字符,这里与正则表达式? (正则?匹配前面表达式0次或者1次)
    []    匹配指定范围内的字符,如: [1-9]匹配1至9内的字符
    [!]   匹配不在指定范围内的字符


    两个主要方法如下。

    1. glob方法:

    glob模块的主要方法就是glob,该方法返回所有匹配的文件路径列表(list);
    该方法需要一个参数用来指定匹配的路径字符串(字符串可以为绝对路径也可以为相对路径),其返回的文件名只包括当前目录里的文件名,不包括子文件夹里的文件。

    1.当前路径下所有py文件
    for fname in glob.glob("**/*.py",recursive=True):
        print(fname)
    
    2.当前路径文件tmp下py文件
    for fname in glob.glob("./tmp/*.py"):
        print(fname)
    
    3.单字通配符?,当前路径文件下以file开头后有一个字符的py文件
    for fname in glob.glob("./file?.py"):
        print(fname)
    
    4.范围通配符[],当前路径文件下以file开头后一个数字符的py文件
    for fname in glob.glob("./file[0-9].py"):
        print(fname)
    
    5.范围通配符[],当前路径文件下以file开头后一个非数字符的py文件
    for fname in glob.glob("./file[!0-9].py"):
        print(fname)
    
    windowns下
    file = glob.glob(r'D:logs**')

    2、iglob方法

    返回一个迭代器iterator,执行效率更高

    1.当前路径文件tmp下py文件,使用iglob,返回迭代器效率更高
    
    >>> glob.iglob('./tmp/*.py')
    <generator object _iglob at 0x7fc140780cd0>
    
    for fname in glob.iglob("./tmp/*.py"):
        print(fname)

    其他

    1.转移字符
    specials = '?*['
    
    for char in specials:
        pattern = '**/*' + glob.escape(char) + '.txt'
        print('Searching for: {!r}'.format(pattern))
        for name in sorted(glob.glob(pattern,recursive=True)):
            print(name)
  • 相关阅读:
    酷狗大数据平台架构是如何重构的
    分层架构,前后端分离有啥坏处?
    Redis快速入门及应用
    Kafka不只是个消息系统
    提高代码质量:如何编写函数
    jquery 回车事件
    程序员的薪资是如何确定出来的?
    HTTP 错误 500.21
    制作手机浏览器显示格式的HTML页面
    操作必须使用一个可更新的查询。
  • 原文地址:https://www.cnblogs.com/dxnui119/p/13804697.html
Copyright © 2011-2022 走看看