用python判断文件类型,python判断文件格式
任何编程语言都离不开文件操作。文件操作主要是帮助我们创建和打开文件,读取文件中的内容,或者把我们要保存的内容写入文件,或者管理文件目录等。下面文章主要介绍几种用Python判断文件的方法以及它们的优缺点的相关资料。有需要的朋友可以参考一下。
00-1010前言懒惰尝试语句传统os模块和时尚pathlib模块的几种方法的优缺点比较和总结
目录
我们知道当一个文件不存在时,open()方法会在写入模式和追加模式下都创建一个新文件,但是判断文件的场景有很多。比如爬虫下载图片时,可能需要判断文件是否存在,避免重复下载;例如,当创建一个新文件时,可能需要判断该文件是否存在,如果存在,则首先进行备份.所以还是要学会判断文件是否存在。
学习是一个循序渐进的过程。如果能建立知识点之间的联系,进行系统的学习,对效果会更有帮助。读完这篇文章,你会读到以下内容:
1.判断文件的方法(try语句、os模块、pathlib模块)
2.上述方法的优缺点比较
前言
我们之前学过,应该使用with statement来处理文件读写,但是with statement并不是万能的,所以我们不得不注意一些异常情况。
比如使用open()方法时,如果文件不存在,程序会抛出FileNotFoundError异常,如果权限不足,会抛出PersistenceError异常。
用open(python.log , r )作为f:
. f .读数()
-
.(略)
FileNotFoundError: [Errno 2]没有此类文件或目录: python.log
为了避免这些异常导致的程序中断,我们可以使用try…except…语句来捕捉异常,然后在except子句中处理异常。
但是,在猫的眼里,不推荐这种方法。原因有二。首先,这种方法非常被动,程序的健康状况会受到不可预测的异常的影响。第二,当文件不存在时,我们可能需要创建文件。如果把这些逻辑写在except子句里,可读性太差。
懒人的try语句
顾名思义,Python内置的os模块是用来与OS(操作系统)交互的模块。它可以实现许多在命令行下完成的操作,如获取操作系统信息、获取/修改环境变量、执行目录操作(创建、删除、遍历)和各种文件操作等。下面,我们要学习几个与文档判断密切相关的方法。
1.os.path.exists()用于判断文件和文件夹是否存在(注意:因为两者都可以判断,为了有效区分文件和文件夹,最好确保文件名有后缀):
导入操作系统
#文件存在还是不存在
os.path.exists(test.txt) True
os.path.exists(cat.txt) False
#文件夹存在与不存在
OS . path . exists( cat/images )True
OS . path . exists( cat/image )False
2.os.path.isfile()、os.path.isdir()判断给定路径是文件还是文件夹:
OS . path . is file( cat/images )False
OS . path . is dir( cat/images )True
os.path.isfile(test.txt) True
3.os.access()检测文件路径的访问权限。语法:OS。os.access(路径,模式););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 pathlibfile_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就会胜出一筹。
总结
到此这篇关于利用Python判断文件的几种方法及其优劣对比的文章就介绍到这了,更多相关Python判断文件内容请搜索盛行IT软件开发工作室以前的文章或继续浏览下面的相关文章希望大家以后多多支持盛行IT软件开发工作室!
郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。