Python 如何查找特定类型文件


Posted in Python onAugust 17, 2020

写在之前

今天的文章是介绍如何用 Python 去定位特定类型的文件,会讲到用字符串匹配文件名定位特定文件以及顺带介绍一下遍历目录树的函数,通过今天的这一部分以及之前文章讲到的文件获取属性的操作,可以做很多有意思的事情。

定位特定文件

定位特定的文件,可以使用 fnmatch 以及 glob 这两个标准库,我们下面来分别看一下。

1. 使用 fnmatch 标准库

一般的话我们想要查找特定类型的文件,可以通过字符串的前缀匹配和后缀匹配来查找,具体实例如下所示:

>>> import os
>>> [txt for txt in os.listdir('.') if txt.endswith('.txt')]
['b.txt', 'a.txt']

其实大部分的情况下这种用字符串匹配的方法来查找文件就足够可以满足需要,如果有些情况下需要更加灵活一点的字符串匹配,就可以使用 fnmatch 库,这是一个专门用来进行文件名匹配的库,支持使用通配符来进行文字匹配(比如'*','?'等)。

fnmatch 这个库很简单,只有 4 个函数:fnmatch,fnmatchcase,filter,translate:

  • fnmatch:判断文件名是否符合特定的模式;
  • fnmatchcase:判断文件名是否符合特定的模式(不区分大小写);
  • filter:返回输入列表中,符合特定模式的文件名列表;
  • translate:将通配符模式转换成正则表达式。

上面 4 个最常用是它的同名函数 fnmatch ,我的当前目录下有 4 个文件,分别是:a.txt,b.txt,c.py,test.py,下面我就用 fnmatch 函数来对当前目录下的这 4 个文件进行匹配性测试,具体请看下面代码:

>>> import os
>>> import fnmatch
>>> os.listdir('.')
['test.py', 'c.py', 'b.txt', 'a.txt']
>>> [txt for txt in os.listdir('.') if fnmatch.fnmatch(txt, '*.txt')]
['b.txt', 'a.txt']
>>> [file for file in os.listdir('.') if fnmatch.fnmatch(file, '[a-c]*')]
['c.py', 'b.txt', 'a.txt']
>>> [file for file in os.listdir('.') if fnmatch.fnmatch(file, '[!a-c]*')]
['test.py']

fnmatchcase 函数与 fnmatch 函数几乎一样,只是在匹配的时候会忽略大小写字母;filter 函数与 fnmatch 比较类似,区别在于fnmatch 一次只对一个文件名匹配,而 filter 一次可以对多个文件名进行匹配判断,下面我们就再来看一下 filter 的用法:

>>> import os
>>> import fnmatch
>>> file = os.listdir('.')
>>> file
['test.py', 'c.py', 'b.txt', 'a.txt']
>>> fnmatch.filter(file, '[a-c]*')
['c.py', 'b.txt', 'a.txt']
>>> fnmatch.filter(file, '[!a-c]*')
['test.py']

2.使用 glob 定位

我们在上面介绍的获取特定类型的文件列表,首先是通过 os.listdir 获取全部的文件列表,然后通过字符串匹配或者使用 fnmatch 进行文件名模式匹配来定位,习惯了 Python 的简洁优雅,这多出来的一步总觉得哪里怪怪的,好在我现在知道了 glob。

glob 的作用相当于 os.listdir + fnmatch 的组合,使用 glob 以后,就不需要用 os.listdir 获取文件列表,直接通过模式匹配就可以解决了,具体操作如下所示:

>>> import glob
>>> glob.glob('*.txt')
['b.txt', 'a.txt']
>>> glob.glob('[a-c]*')
['c.py', 'b.txt', 'a.txt']
>>> glob.glob('[!a-c]*')
['test.py']

可以看到,Python 真的非常的灵活,光是定位目录下特定的文件类型我就已经介绍了 3 种方式,一般情况下就用字符串匹配就可以解决,如果需要更加灵活一点的的,可以使用 fnmatch 和 glob。

遍历目录树

再上一节中我们都是查找某个目录下的文件然后通过匹配去定位自己需要的文件类型。但是在实际的应用过程中我们更可能遇到的是某个目录及其子目录下的所有文件。比如查找某个目录及其子目录下所有的 txt 文件等等,对于这类的需求,我们可以使用 os 模块下的「walk」函数。walk 函数遍历某个目录及其子目录,对于每一个目录,walk 返回一个三元组,依次是「当前目录」,「当前目录下的子目录」,「当前目录下的文件列表」。

下面我们来演示一下 os.walk 函数的用法,做一个小的练习,来遍历一下 /root/rocky0429 目录及其子目录下的所有 txt 和 图片文件:

import os
import fnmatch

search = ['*.txt', '*.jpg', '*.jpeg']
res = []

for root, dirnames, filenames in os.walk(os.path.expanduser('~/rocky0429')):
  for extension in search:
    for filename in fnmatch.filter(filenames, extension):
      res.append(os.path.join(root,filename))

    print(res)

以上就是Python 如何查找特定类型文件的详细内容,更多关于python 查找文件的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
python的numpy模块安装不成功简单解决方法总结
Dec 23 Python
python3利用tcp实现文件夹远程传输
Jul 28 Python
matplotlib.pyplot画图并导出保存的实例
Dec 07 Python
python实现高斯投影正反算方式
Jan 17 Python
Python打包工具PyInstaller的安装与pycharm配置支持PyInstaller详细方法
Feb 27 Python
python+gdal+遥感图像拼接(mosaic)的实例
Mar 10 Python
Python unittest单元测试框架及断言方法
Apr 15 Python
django 模版关闭转义方式
May 14 Python
Django中FilePathField字段的用法
May 21 Python
基于Pytorch版yolov5的滑块验证码破解思路详解
Feb 25 Python
pytorch 实现在测试的时候启用dropout
May 27 Python
python可视化大屏库big_screen示例详解
Nov 23 Python
Python 通过爬虫实现GitHub网页的模拟登录的示例代码
Aug 17 #Python
无需压缩软件,用python帮你操作压缩包
Aug 17 #Python
用Python制作mini翻译器的实现示例
Aug 17 #Python
PyCharm vs VSCode,作为python开发者,你更倾向哪种IDE呢?
Aug 17 #Python
pandas apply多线程实现代码
Aug 17 #Python
简述python Scrapy框架
Aug 17 #Python
python使用多线程查询数据库的实现示例
Aug 17 #Python
You might like
第1次亲密接触PHP5(2)
2006/10/09 PHP
PHP中获取时间的下一周下个月的方法
2014/03/18 PHP
Zend Framework页面缓存实例
2014/06/25 PHP
php文件下载处理方法分析
2015/04/22 PHP
PHP dirname(__FILE__)原理及用法解析
2020/10/28 PHP
javascript Math.random()随机数函数
2009/11/04 Javascript
JS 面向对象之神奇的prototype
2011/02/26 Javascript
jquery 读取页面load get post ajax 四种方式代码写法
2011/04/02 Javascript
JavaScript 学习笔记之基础中的基础
2015/01/13 Javascript
Javascript URI 解析介绍
2015/03/15 Javascript
jQuery处理XML文件的几种方法
2016/06/14 Javascript
Bootstrap 布局组件(全)
2016/07/18 Javascript
纯js和css完成贪吃蛇小游戏demo
2016/09/01 Javascript
jQuery插件FusionCharts绘制的2D帕累托图效果示例【附demo源码】
2017/03/28 jQuery
javascript 判断一个对象为数组的方法
2017/05/03 Javascript
Vue-cli-webpack搭建斗鱼直播步骤详解
2017/11/17 Javascript
jQuery实现鼠标点击处心形漂浮的炫酷效果示例
2018/04/12 jQuery
vue中实现左右联动的效果
2018/06/22 Javascript
ES6入门教程之变量的解构赋值详解
2019/04/13 Javascript
详解Python中for循环的使用
2015/04/14 Python
python3.5实现socket通讯示例(TCP)
2017/02/07 Python
快速实现基于Python的微信聊天机器人示例代码
2017/03/03 Python
Python实现将HTML转换成doc格式文件的方法示例
2017/11/20 Python
Python数据结构与算法之二叉树结构定义与遍历方法详解
2017/12/12 Python
python使用Turtle库绘制动态钟表
2018/11/19 Python
Pytorch中膨胀卷积的用法详解
2020/01/07 Python
Python接口测试环境搭建过程详解
2020/06/29 Python
CSS3 实现时间轴动画
2020/11/25 HTML / CSS
英国复古服装和球衣购买网站:3Retro Football
2018/07/09 全球购物
New Balance比利时官方网站:购买鞋子和服装
2021/01/15 全球购物
施工材料员岗位职责
2014/02/12 职场文书
小学三年级学生评语
2014/04/22 职场文书
学校四风对照检查材料
2014/08/28 职场文书
2014年人事专员工作总结
2014/11/19 职场文书
毕业生评语大全
2015/01/04 职场文书
Python中基础数据类型 set集合知识点总结
2021/08/02 Python