设为首页 收藏本站
查看: 1450|回复: 0

[经验分享] python目录遍历和删除指定目录下的pyc文件

[复制链接]

尚未签到

发表于 2015-4-26 08:47:43 | 显示全部楼层 |阅读模式
  在提交版本库的时候需要清除工作目录下的pyc文件,在《python cookbook》2.16节中提供了一种遍历目录树并找出指定文件的方法,可以利用这个清除工作目录下的pyc文件。
  我做了简单的注释,并在pattern的调用中加入了strip方法以去除其两端的空格,来防止patterns字符串在以分号分割的同时因存在空格而无法匹配的情况。
  遍历目录树


#!/user/bin/python
# -*- coding: utf-8 -*-
# Filename:  allfile.py
# Date:2011-03-26

import os
import fnmatch
def all_file(root, patterns='*',single_level=False, yield_folders=False):
        """
        root:            需要遍历的目录
        patterns:       需要查找的文件,以;为分割的字符串
        single_level:    是否只遍历单层目录,默认为否
        yield_folders:   是否包含目录本身,默认为否
        """
        patterns = patterns.split(';')
        for path, subdirs, files in os.walk(root):
            if yield_folders:
                files.extend(subdirs)
            files.sort()
            for name in files:
                for pattern in patterns:
                    if fnmatch.fnmatch(name, pattern.strip()):# 去除pattern两端的空格
yield os.path.join(path, name)
            if single_level:
                break  os.walk
  os.walk是一个generator函数。每次可以得到一个三元tupple,其中第一个为起始路径,第二个为起始路径下的文件夹,第三个是起始路径下的文件。举例如下:


>>> x=os.walk('/home/tiny/workspace/py')
>>> x

>>>for i in x:
...     i
...
('/home/tiny/workspace/py', ['2', '1'], ['.allfile.py.swp', 'allfile.py', 'list_get.py', 'test.py', 'tags', 'log.txt'])
('/home/tiny/workspace/py/2', [], ['fib.py', 'djcoding.py', 'drectory_travel.py', 'foo.py'])
('/home/tiny/workspace/py/1', [], ['timetest2.py', 'timetest.py'])  fnmatch 实现shell风格模式匹配特定字符

  • fnmatch.fnmatch(names, pattern):测试name是否匹配pattern,返回true/false。下面的例子列出了当前目录中的所有py文件:


>>>import fnmatch
>>>import os
>>>for file in os.listdir('.'):
...     if fnmatch.fnmatch(file, '*.py'):
...         print file
...
allfile.py
list_get.py
test.py  如果操作系统是大小写不敏感的,则在fnmatch.fnmatch()中所有的参数将被统一格式为所有大写或所有小写。

  • fnmatch.fnmatchcase( names, pattern):与平台无关的大小写敏感的fnmatch.fnmatch
  • fnmatch.filter(names, pattern):实现列表特殊字符的过滤或筛选,返回符合匹配模式的字符列表,例:


>>> files=['tags', 'readme.txt', 'allfile.py', 'test.py']
>>> fnmatch.filter(files, '*.py')
['allfile.py', 'test.py']
>>> fnmatch.filter(files, '[tx]')
[]
>>> fnmatch.filter(files, '[tx]*')
['tags', 'test.py']
>>> fnmatch.filter(files, '[tr]*')
['tags', 'readme.txt', 'test.py']
>>> fnmatch.filter(files, '*[tr]*')
['tags', 'readme.txt', 'test.py']
>>> fnmatch.filter(files, '?[a]*')
['tags']  注意: [seq] 匹配单个seq中的任意单个字符

  • fnmatch.translate(pattern):翻译模式, fnmatch将这种全局模式转换成一个正则式, 然后使用re模块来比较名字和模式。 translate() 函数是一个公共API用于将全局模式转换成正则式。


>>>import fnmatch
>>> pattern='*.py'
>>>print fnmatch.translate(pattern)
.*\.py\Z(?ms)

  • unix shell风格匹配方式

  • *表示匹配任何单个或多个字符
  • ?表示匹配单个字符
  • [seq] 匹配单个seq中的任意单个字符
  • [!seq]匹配单个不是seq中的任意单个字符
  回到开始,删除pyc文件
  os.remove()可以删除指定文件,参见文档。删除pyc可以在以上遍历的基础上加入代码:


if__name__=='__main__':
        for path in all_file(os.getcwd(),'*.pyc'):
                print path
                os.remove(path)  os.getcwd() 是获取当前文件夹,也可以用指定目录代替,如;'\home'.
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-60737-1-1.html 上篇帖子: python websocket 下篇帖子: 从Python到Ruby(翻译)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表