利用Python判断文件的几种方法及其优劣对比
作者:编程学习网 发布时间:2022-07-03 06:20:02
前言
我们知道当文件不存在的时候,open()方法的写模式与追加模式都会新建文件,但是对文件进行判断的场景还有很多,比如,在爬虫下载图片的时候,可能需要判断文件是否存在,以免重复下载;又比如,创建新文件的时候,可能需要判断文件是否存在,存在就先做个备份……所以,学习判断文件是否存在,还是很有必要的。
学习是循序渐进的过程,若能建立知识点间的联系,进行系统性的学习,那将更有助于效果。阅读这篇文章,你将读到如下内容:
1、判断文件的方法(try语句、os模块、pathlib模块)
2、以上几种方法的优劣对比
懒人的try语句
我们之前学过,要用with语句来处理文件读写,但with语句也不是万能的,所以还得关注一些异常情况。
例如,当使用open()方法的时候,如果文件不存在,程序会抛出FileNotFoundError异常,而如果权限不足的话,就会抛出PersmissionError异常。
with open("python.log", "r") as f:
...: f.read()
-----------------------
...(略)
FileNotFoundError: [Errno 2] No such file or directory: 'python.log'
为了避免这些异常导致程序中断,我们可以用try…except…语句来捕捉异常,然后在except子句进行异常的处理。
不过,在猫猫看来,这个方法不值得推荐。原因有二,一是这种方法很被动,程序的健康受制于不可预测的异常;二是当文件不存在的时候,我们可能需要去创建文件,这些逻辑如果写在except子句里,可读性太差了。
传统的os模块
顾名思义,Python内置的os模块是用来与OS(操作系统)进行交互的模块,它可以实现很多在命令行下做的操作,例如,获取操作系统信息、获取/修改环境变量、进行目录操作(创建、删除、遍历)和各种文件操作等等。下面,我们要学习的是跟文件判断密切相关的几个方法。
1、os.path.exists()用于判断文件及文件夹是否存在(注意:因为两者都能判断,为了有效区分文件和文件夹,最好保证文件名是带后缀的):
import os
# 文件存在 VS 不存在
os.path.exists("test.txt") >>>True
os.path.exists("cat.txt") >>>False
# 文件夹存在 VS 不存在
os.path.exists("cat/images") >>>True
os.path.exists("cat/image") >>>False
2、os.path.isfile()、os.path.isdir() 判断给定的路径是文件还是文件夹:
os.path.isfile("cat/images") >>>False
os.path.isdir("cat/images") >>>True
os.path.isfile("test.txt") >>>True
3、os.access()检测文件路径的访问权限,语法:os.access(path, mode);其中path指的是文件或者文件夹,mode指的是要检测的模式:
os.access("cat/images", os.F_OK) >>>True # path存在
os.access("cat/images", os.R_OK) >>>True # path可读
os.access("cat/images", os.W_OK) >>>True # path可写
os.access("cat/images", os.X_OK) >>>True # path可执行
4、os模块中其它常用方法:
os.mkdir()创建目录、os.rmdir()删除目录、os.rename()重命名、os.remove()删除文件、os.path.join()连接目录与文件名、os.path.split()分割目录与文件名……(不一一举例了,今后有机会再作介绍)
时尚的pathlib模块
pathlib模块是python3.4才加入的模块,官方介绍它是面向对象的文件系统路径(Object-oriented filesystem paths),这是一个很强大的模块,文末附录了官方文档地址。
这里主要介绍几个基本的用法:
import pathlib
file_obj = pathlib.Path("test.txt")
file_obj.name >>>'test.txt' # 文件名
file_obj.exists() >>> True # 是否存在
file_obj.is_dir() >>>False # 是否文件夹
file_obj.is_file() >>>True # 是否文件
几种方法优劣对比
围绕文件操作的知识很多,限于篇幅,本文主要对判断文件作了介绍,今后也许还会对其它具体话题进行学习。
现在知道了几种判断文件是否存在的方法,猫猫试着根据自己的理解,对它们做一下评判。
首先,try语句的缺点是没有主动做判断,不方便根据文件是否存在而做针对性的处理,它把必要的逻辑交给异常捕获,多少显得“不负责任”;try语句也有优点,一是不需要引入模块,不需要区分各种使用方法,二是将其它可能存在的异常都打包,避免多系统或者多场景的遗漏。
os模块是传统的老模块了,在使用上和维护上都会比较顺畅;它的主要缺点在于有的方法比较繁琐,比如由于使用字符串来表示文件路径,这会导致路径拼接上的麻烦。另外,不同操作系统在路径分隔符上的差异(Windows使用\分隔符,Linux和Mac使用/分隔符),也可能导致难以发现的错误。
相对来说,pathlib功能最强大,但普及度比较低,有一定的学习门槛;它主要的优点是面向对象,同时,因为对不同操作系统的特性做了封装,能有效避免字符串表示文件路径的难题。它也有不足之处,即没有像os.access()这种可以检测访问权限的方法,虽然这个方法基本不会使用到。
下面比较了三种拼接文件路径的方法,方法一未对分隔符做处理,不能保证在每个操作系统都能找到;方法二需要反复使用os.path.join;方法三只用“/"就能拼接路径,而且肯定支持多操作系统。
# 错误拼接:未处理分隔符
data_folder = "source_data/text_files/"
file_to_open = data_folder + "test.txt"
# os模块拼接
import os
data_folder = os.path.join("source_data", "text_files")
file_to_open = os.path.join(data_folder, "test.txt")
# pathlib模块拼接
from pathlib import Path
data_folder = Path("source_data/text_files/")
file_to_open = data_folder / "test.txt"
总结一下,如果文件路径简单,仅仅要用到exists()、is_dir()、is_file() 这几个方法的话,os.path模块和pathlib.Path模块不分伯仲,都很好用,但是如果考虑到繁复的路径拼接的话,pathlib.Path就会胜出一筹。
来源:https://juejin.cn/post/7111159430544113678
猜你喜欢
- TensorFlow中tf.batch_matmul()用法如果有两个三阶张量,size分别为a.shape = [100, 3, 4]b.
- 在实用美术中,常有"远看色彩近看花,先看颜色后看花,七分颜色三分花"的说法。这也就说明,在任何设计中,色彩对视觉的刺激起
- 用习惯列表解析之后会觉得超级酷,所以在尝试使用列表解析,把循环什么的写在一行里面。使用if的时候什么时候必须要有else,什么时候可以没有e
- 七夕节简介每年农历七月初七这一天是我国汉族的传统节日七夕节。因为此日活动的主要参与者是少女,而节日活动的内容又是以乞巧为主,故而人们称这天为
- 阿里云提供了基于命名空间的 V2 版 SDK,但是文档不是很完整,使用门槛比较高,于是我封装了一个 Composer 包:https://g
- MySQL 5.0.16的乱码问题可以用下面的方法解决:1.设置phpMyAdminLanguage:Chinese simplified
- canal简介由阿里巴巴开源 github地址:https://github.com/alibaba/canalCanal是阿里巴巴开源的一
- 当数据库服务器变得十分繁忙导致性能下降时,你会怎么办?购买更多的硬件升级你的服务器,还是重新考虑数据库服务器设计使得数据库平台具备良好的可升
- 环境Laravel 5.4原理在Laravel中,门面为应用服务容器中绑定的类提供了一个“静态”接口
- 问:如何自己制作验证码的head.fix和body.fix文件答:1 图象绘制完成后,将文件存为24位位图格式的BMP图象文件。 2 去除前
- 新闻系统、blog系统等都可能用到将动态页面生成静态页面的技巧来提高页面的访问速度,从而减轻服务器的压力,本文为大家搜集整理了ASP编程中常
- 页面自动刷新代码大全,基本上所有要求自动刷新页面的代码都有,大家可以自由发挥做出完美的页面。 1)10表示间隔10秒刷 ...页面自动刷新代
- 如下所示:def list_dict_duplicate_removal(): data_list = [{"a&qu
- 网页开发人员常常希望能够了解并掌握多种语言,结果是,学习一门语言的所有内容是棘手的,但是却很容易发现你并没有完全利用那些比较特殊却很有用的标
- 我们生活在信息繁杂的社会,尤其是在互联网时代,人们开始通过网络开始接触越来越多的信息,那么,如何获取/传递有效而准确的信息将非常重要。在网页
- 一、数据库远程管理技术 对于中小型应用,比如一个网站的建设和维护,这种大型应用平台就显得有些尾大不掉,开销也过于庞大。曾经在互联网技术和Ja
- 嵌套SELECT语句也叫子查询,形如:SELECT name FROM bbc WHERE region = (SELECT region
- int connectDb() { EXEC SQL BEGIN DECLARE SECTION; char username[20]; c
- 最近研究研究了css,少不了去网上分析一下别人的网页, 但很多网站的css文件都是要么写在一行,要么一个换行都没有,看起来极其痛苦,所以写一
- 说明1、模型集成是指将一系列不同模型的预测结果集成在一起,从而获得更好的预测结果。2、对于模型集成来说,模型的多样性非常重要。Diversi