百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

再谈文件读写:判断文件的几种方法及其优劣对比

off999 2024-10-12 06:18 62 浏览 0 评论

上周,猫猫写了一篇给Python学习者的文件读写指南,跟大家一起详尽地学习了文件读写的基础内容,以及with语句与上下文管理器的进阶知识。

这份指南虽然写得很用心,但是因为只关注了文件读写的核心内容,所以也有美中不足不处,有些在实战中所需的知识点没有谈到,例如,为了能够进行文件读写,首先得找到文件、文件得可读写才行。

我们知道当文件不存在的时候,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就会胜出一筹。

喵喵,今天的分享就到这啦,小伙伴们觉得有用的话,麻烦帮忙点赞、转发给其他童靴哦~~~

另外,为了回馈各位好学的胖友们,猫猫精选了20本电子书,现在去后台回复【爱学习】,即可免费获得哦喵~~~

扩展阅读:

给Python学习者的文件读写指南

https://mp.weixin.qq.com/s/Md07VoaULda7qnMO4ob7Ww

菜鸟教程:os模块

http://www.runoob.com/python/os-file-methods.html

官方文档:pathlib模块

https://docs.python.org/3/library/pathlib.html

相关推荐

PYTHON-简易计算器的元素介绍

[烟花]了解模板代码的组成importPySimpleGUIassg#1)导入库layout=[[],[],[]]#2)定义布局,确定行数window=sg.Window(&#...

如何使用Python编写一个简单的计算器程序

Python是一种简单易学的编程语言,非常适合初学者入门。本文将教您如何使用Python编写一个简单易用的计算器程序,帮助您快速进行基本的数学运算。无需任何高深的数学知识,只需跟随本文的步骤,即可轻松...

用Python打造一个简洁美观的桌面计算器

最近在学习PythonGUI编程,顺手用Tkinter实现了一个简易桌面计算器,功能虽然不复杂,但非常适合新手练手。如果你正在学习Python,不妨一起来看看这个项目吧!项目背景Tkint...

用Python制作一个带图形界面的计算器

大家好,今天我要带大家使用Python制作一个具有图形界面的计算器应用程序。这个项目不仅可以帮助你巩固Python编程基础,还可以让你初步体验图形化编程的乐趣。我们将使用Python的tkinter库...

用python怎么做最简单的桌面计算器

有网友问,用python怎么做一个最简单的桌面计算器。如果只强调简单,在本机运行,不考虑安全性和容错等的话,你能想到的最简单的方案是什么呢?我觉得用tkinter加eval就够简单的。现在开整。首先创...

说好的《Think Python 2e》更新呢!

编程派微信号:codingpy本周三脱更了,不过发现好多朋友在那天去访问《ThinkPython2e》的在线版,感觉有点对不住呢(实在是没抽出时间来更新)。不过还好本周六的更新可以实现,要不就放一...

构建AI系统(三):使用Python设置您的第一个MCP服务器

是时候动手实践了!在这一部分中,我们将设置开发环境并创建我们的第一个MCP服务器。如果您从未编写过代码,也不用担心-我们将一步一步来。我们要构建什么还记得第1部分中Maria的咖啡馆吗?我们正在创...

函数还是类?90%程序员都踩过的Python认知误区

那个深夜,你在调试代码,一行行检查变量类型。突然,一个TypeError错误蹦出来,你盯着那句"strobjectisnotcallable",咖啡杯在桌上留下了一圈深色...

《Think Python 2e》中译版更新啦!

【回复“python”,送你十本电子书】又到了周三,一周快过去一半了。小编按计划更新《ThinkPython2e》最新版中译。今天更新的是第五章:条件和递归。具体内容请点击阅读原文查看。其他章节的...

Python mysql批量更新数据(兼容动态数据库字段、表名)

一、应用场景上篇文章我们学会了在pymysql事务中批量插入数据的复用代码,既然有了批量插入,那批量更新和批量删除的操作也少不了。二、解决思路为了解决批量删除和批量更新的问题,提出如下思路:所有更新语...

Python Pandas 库:解锁 combine、update 和compare函数的强大功能

在Python的数据处理领域,Pandas库提供了丰富且实用的函数,帮助我们高效地处理和分析数据。今天,咱们就来深入探索Pandas库中四个功能独特的函数:combine、combine_fi...

记录Python3.7.4更新到Python.3.7.8

Python官网Python安装包下载下载文件名称运行后选择升级选项等待安装安装完毕打开IDLE使用Python...

Python千叶网原图爬虫:界面化升级实践

该工具以Python爬虫技术为核心,实现千叶网原图的精准抓取,突破缩略图限制,直达高清资源。新增图形化界面(GUI)后,操作门槛大幅降低:-界面集成URL输入、存储路径选择、线程设置等核心功能,...

__future__模块:Python语言版本演进的桥梁

摘要Python作为一门持续演进的编程语言,在版本迭代过程中不可避免地引入了破坏性变更。__future__模块作为Python兼容性管理的核心机制,为开发者提供了在旧版本中体验新特性的能力。本文深入...

Python 集合隐藏技能:add 与 update 的致命区别,90% 开发者都踩过坑

add函数的使用场景及错误注意添加单一元素:正确示例:pythons={1,2}s.add(3)print(s)#{1,2,3}错误场景:试图添加可变对象(如列表)会报错(Pytho...

取消回复欢迎 发表评论: