python 递归遍历文件夹,并打印满足条件的文件路径实例
题目:利用协程来遍历目录下,所有子文件及子文件夹下的文件是否含有某个字段值,并打印满足条件的文件的绝对路径。
#!/user/bin/env python # -*- coding:utf-8 -*- #grep -rl "python" D:\devtools\workspace\python\aaa import os def init(func): def wrapper(*args,**kwargs): res=func(*args,**kwargs) res.send(None) return res return wrapper @init def search(target): '找到文件的绝对路径' while True: dir_name=yield g=os.walk(dir_name) for i in g: for j in i[-1]: file_path="%s\\%s"%(i[0],j) target.send(file_path) @init def get_file_handle(target): '获取文件句柄' while True: file_path=yield with open(file_path) as f: target.send((file_path,f)) @init def cat_file(target): '读取文件' while True: file_path,f=yield for line in f: target.send((file_path,line)) @init def printer(pattern): '打印满足过滤条件的文件' s=set() while True: file_path,line=yield if pattern in line: if file_path not in s: print(file_path) s.add(file_path) g=search(get_file_handle(cat_file(printer("python")))) g.send("D:\\devtools\\workspace\\python\\aaa")
使用装饰器以后,无需再每次执行.send(None),形参target接收的是一个生成器。
整个编程采用了面向过程的思路。
面向过程需要把整个流程设计出来。
其好处就是:a.体系结构更加清晰;b.简化了程序的复杂度
缺点:不具有可扩展性(内部耦合度太高)
具体应用场景:那些长期不需要怎么变化的软件。如系统
以上这篇python 递归遍历文件夹,并打印满足条件的文件路径实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。
相关推荐
-
详解shell 遍历文件夹内所有文件并打印绝对路径
例如你有一个文件夹路径是 /wls,如果想要遍历这个文件夹内的所有文件,并将它们保存到数组中,利用shell你可以这样做 for file in /wls/* do if test -f $file then arr=(${arr[*]} $file) fi done echo ${arr[@]} 这样就可以遍历wls文件夹下的所有文件并把它们的绝对路径存在arr这个数组中,但这还是不够的,因为文件夹中可能会有多个子文件夹,如果只过滤文件会遗漏掉子文件夹中的文件,所以需要扩展上面的方法,如果我们
-
Python 遍历子文件和所有子文件夹的代码实例
最近看ECShop到网上找资料,发现好多说明ECShop的文件结构不全面,于是想自己弄个出来.但这是个无聊耗时的工作,自己就写了个Python脚本,可以递归遍历目录下的所有文件和所有子目录,并将结果记录到一个.xml文件中(因为想使用Notepad++的代码折叠功能,所以使用.xml文件). 下面就是Python代码: # -*- coding: cp936 -*- ############################################# # Written By Qian_F
-
python中遍历文件的3个方法
今天写一个在windows下批量修改文件名的python脚本,用到文件的遍历.用python进行文件遍历有多种方法,这里列举并说明一下. os.path.walk() 这是一个传统的用法. walk(root,callable,args)方法有三个参数:要遍历的目录,回调函数,回调函数的参数(元组形式). 调用的过程是遍历目录下的文件或目录,每遍历一个目录,调用回调函数,并把args作为参数传递给回调函数. 回调函数定义时也有三个参数,比如示例中的func中的三个参数,分别为walk传来的参数.
-
Python中文件遍历的两种方法
关于Python的文件遍历,大概有两种方法,一种是较为便利的os.walk(),还有一种是利用os.listdir()递归遍历. 方法一:利用os.walk os.walk可以自顶向下或者自底向上遍历整个文件树,然后返回一个含有3个元素的tuple,(dirpath, dirnames, filenames),要注意的是,os.walk()会返回一个generater,所以调用的时候一定要放到for循环中. 复制代码 代码如下: import osdef walk_dir(dirname): f
-
python 递归遍历文件夹,并打印满足条件的文件路径实例
题目:利用协程来遍历目录下,所有子文件及子文件夹下的文件是否含有某个字段值,并打印满足条件的文件的绝对路径. #!/user/bin/env python # -*- coding:utf-8 -*- #grep -rl "python" D:\devtools\workspace\python\aaa import os def init(func): def wrapper(*args,**kwargs): res=func(*args,**kwargs) res.send(Non
-
Python导入父文件夹中模块并读取当前文件夹内的资源
在某些特殊情况下,我们的 Python 脚本需要调用父目录下的其他模块.例如: 在编写 GNE 的测试用例时,有一个脚本 generate_new_cases.py放在 tests文件夹中.而 tests 文件夹与 gne 文件夹放在同一个位置.其中 gne 文件夹是一个包.我现在需要从generate_new_cases.py 文件中导入 gne 里面的一个类GeneralNewsExtractor. 为了简化问题,我单独写了一个演示的样例.它的文件结构与每个文件中的内容如下: 现在,我直接在
-
Python递归遍历列表及输出的实现方法
本文实例讲述了Python递归遍历列表及输出的实现方法.分享给大家供大家参考.具体实现方法如下: def dp(s): if isinstance(s,(int,str)): print(s) else: for item in s: dp(item) l=['jack',('tom',23),'rose',(14,55,67)] dp(l) 运行结果如下: jack tom 23 rose 14 55 67 希望本文所述对大家的Python程序设计有所帮助.
-
python判断文件夹内是否存在指定后缀文件的实例
该代码主要是基于python实现判断指定文件夹下是否存在指定后缀的文件.代码如下: import os Your_Dir='你的文件夹/' Files=os.listdir(Your_Dir) for k in range(len(Files)): # 提取文件夹内所有文件的后缀 Files[k]=os.path.splitext(Files[k])[1] Str2=['.wav','.mp3','.mp4'] if len(list(set(Str2).intersection(set(Fil
-
python高效过滤出文件夹下指定文件名结尾的文件实例
如下所示: import os def anyTrue(predicate, sequence): return True in map(predicate, sequence) def filterFiles(folder, exts): for fileName in os.listdir(folder): if os.path.isdir(folder + '/' + fileName): filterFiles(folder + '/' + fileName, exts) elif an
-
java实现输出文件夹下某个格式的所有文件实例代码
package file; import java.io.File; /** * 输出某个文件夹下所有某个格式的文件 * @author hasee * */ public class Demo2 { public static void main(String[] args) { getTxtName("d:/a",".jpg"); } public static void getTxtName(String path,String suffix) { //判断文
-
C#删除只读文件或文件夹(解决File.Delete无法删除文件)
C#删除只读文件的方法: if (File.GetAttributes(FFName).ToString().IndexOf("ReadOnly") != -1) File.SetAttributes(FFName, FileAttributes.Normal); File.Delete(FFName);//不能删除只读文件 C#删除只读文件夹的方法: 只读文件夹删除需要先删除文件夹内的文件,然后在使用删除文件夹才能成功,否则将会报没有权限访问. 下面是遍历删除文件夹代码 /// &l
-
Matlab实现获取文件夹下所有指定后缀的文件
目录 1. 要求 2. 代码 3. 参考 1. 要求 获取指定文件夹下(包含子文件夹),所有指定后缀(如txt)的文件路径(即文件所在目录+文件名),返回一个字符串数组. 2. 代码 获取C:/Users/Administrator/Desktop文件夹下(包含子文件夹)的所有.m文件 clear dirOutput = dir('C:/Users/Administrator/Desktop/**/*.m'); folder = string({dirOutput.folder}'); file
-
JFileChooser实现对选定文件夹内图片自动播放和暂停播放实例代码
本案例通过使用JFileChooser实现对选定文件夹内图片实现自动播放和暂停播放 代码如下,如有不合适的地方 还请指教 package com.xiaoqiang; import java.awt.Container; import java.awt.FlowLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.io.File; import javax.swin
-
Node.JS枚举统计当前文件夹和子目录下所有代码文件行数
使用Node.JS的大多数用记事本开发,有时侯会需要统计工程代码量,然后记事本大部分没有这个功能.其实用node.js几行代码就可以实现. var path = require('path') var fs = require('fs') //需要统计的文件类型,可自己删减,均小写 var codesFiles = [ '.css', '.js', '.html', '.tmpl', '.part', '.json', '.md', '.txt', '.yml', '.java', '.cs',
随机推荐
- 全面了解构造函数继承关键apply call
- IIS6下配置fastcgi的php的教程
- JS导出PDF插件的方法(支持中文、图片使用路径)
- Yii数据模型中rules类验证器用法分析
- Python进程通信之匿名管道实例讲解
- 让iframe自适应高度(支持XHTML,支持FF)
- Android网易有道词典案例源码分享
- PHP实现网页内容html标签补全和过滤的方法小结【2种方法】
- 不同方式遍历Map集合(全)
- C#四舍五入(函数)用法实例
- PHP脚本的10个技巧(3)
- php+ajax实现无刷新的新闻留言系统
- 在Windows环境下使用MySQL:实现自动定时备份
- Linux下Mysql定时任务备份数据的实现方法
- eclipse下配置Spring环境的方法步骤
- Android利用OpenGLES绘制天空盒实例教程
- PHP中Static(静态)关键字功能与用法实例分析
- Java 爬虫数据异步加载如何解决
- 详解使用mpvue开发github小程序总结
- 便捷提取python导入包的属性方法