一、先介绍一下os模块
import os print(os.getcwd()) # E:/python/test/python_models # 获取当前的目录 print(os.listdir(".")) # ['oop.py', 'python_argparse.py', 'python_click.py', 'python_os.py', 'python_re.py', 'python_requests.py', 'xx.py', '__init__.py'] # 列出指定目录下的所有文件和文件夹,返回的是一个列表
1、拆分路径的方法介绍
# 1、拆分路径的方法介绍 # os.path模块用来对文件和路径进程管理,显示他包含很多拆分路径的函数,os.path模块中和拆分路径相关的函数有 # os.path.split() 返回一个二元组,包含文件的路径和文件名 # os.path.dirname() 返回文件的路径 # os.path.basename() 返回文件的文件名 # os.path.splitext() 返回一个不包括文件扩展名的部分和文件扩展名的二元组 # 下面演示一下上面介绍的方法 path = "G:/新建文件夹/疯狂/永久地址.txt" print(os.path.split(path)) # ('G://新建文件夹//疯狂', '永久地址.txt') print(os.path.dirname(path)) # G:/新建文件夹/疯狂 print(os.path.basename(path)) print(os.path.splitext(path)) # ('G://新建文件夹//疯狂//永久地址', '.txt')
2、构建文件路径的方法介绍
# 2、构建路径的方法介绍 # python工程师可以使用os.path模块方便的拆分路径,相应的,os.path模块的也包含了用以构建路径的函数,其中最常用的是 # os.path.expanduser() 展开用户的HOME目录,比如~,~username # os.path.abspath() 得到文件或路径的绝对路径 # os.path.join() 根据不同的操作系统平台,使用不用的路径分隔符拼接路径 # 下面演示一下上面介绍的方法 # os.path.expanduser("~mysql") 返回mysql用户的HOME目录,我这里是windows平台,就不演示这个命令了 print(os.path.abspath(".")) # E:/python/test/python_models print(os.path.abspath("..")) # E:/python/test # 相应的有一个方法可以判断一个路径是否为绝对路径 print(os.path.isabs(".")) # False print(os.path.isabs(os.path.abspath("."))) # True print(os.path.join(os.path.abspath("."),"test","join.text")) # E:/python/test/python_models/test/join.text # 在python代码中,可使用__file__这个特殊的变量表示当前代码所在的源文件,在编写代码时,有时候需要导入当前源文件父目录下的软件包,因此需要用到 # 这里的路径函数获取源文件的父目录,如下所示 path = os.path.abspath(__file__) print(path) # E:/python/test/python_models/python_os.py print(os.path.dirname(path)) # E:/python/test/python_models print(os.path.pardir) # .. print(os.path.abspath(os.path.join(os.path.dirname(path),os.path.pardir))) # E:/python/test
3、获取文件属性的方法介绍
# 3、获取文件属性 # os.path模块也包含了若干函数用来获取文件的属性,包括文件的创建时间,修改时间,文件的大小,访问时间 # os.path.getatime() 返回文件的访问的时间 # os.path.getmtime() 返回文件的修改的时间 # os.path.getctime() 返回文件的创建时间 # os.path.getsize() 返回文件的大小
4、判断文件的类型
# 4、判断文件类型 # os.path模块也提供了若干函数用来判断路径是否存爱,以及路径所指的文件的类型,这些判断类的函数一般以is开头,并且返回一个Boolean型的结果 # os.path.exists() 参数path指向的路径是否存在 # os.path.isfile() 参数path指向的路径存在,且为文件 # os.path.isdir() 参数path指向的路径存在,且为目录 # os.path.islink() 参数path指向的路径存在,且是一个连接 # os.path.ismount() 参数path指向的路径存在,且是一个挂载点
5、文件和目录操作
# 5、文件和目录的操作 # os模块保留文件和目录的操作函数,包括创建目录,删除目录,删除文件,重命名文件等 # os.remove() 删除path路径所指向的文件 # os.rmdir() 删除path路径锁指向的文件夹,该文件夹必须为空,否则会报失败 # os.mkdir() 创建一个文件夹 # os.rename() 重命名一个文件或者文件夹
6、修改文件属性和判断文件属性
# 6、修改文件权限和判断文件权限 # os模块也包含了修改文件权限,判断文件权限的函数,即chmod和access,chmod用来修改文件的权限,access用来判断文件是否具有相应的权限,在linux中, # 权限分为读,写和执行,因此os模块也提供了三个常量来表示读,写,执行,即R_OK,W_OK,X_OK print(os.access(__file__,os.R_OK)) # True print(os.access(__file__,os.W_OK)) # True print(os.access(__file__,os.X_OK)) # True os.chmod(__file__,os.W_OK)
7、遍历目录树
# 8、os.walk遍历目录树 # 前面的例子都是查找某一个目录下的文件并通过模式匹配去选择自己需要的文件类型,在实际工作中,更有可能遇到的是查找某个目录及其子目录下的所有的文件 # 。例如查找某个目录及其子目录下所有的图片,查找某个目录及其子目录下最大的十个文件,对于这类的需求可以使用os模块walk方法,walk方法遍历某个目录及其 # 子目录,对于每一个目录,walk返回一个三元组,dirpath,dirnames,filenames,其中dirpath保存的是当前的目录,dirnames是当前目录下的子目录列表,filenames # 是当前目录下的文件列表 for a,b,c in os.walk(".."): print(a,b,c,"walk---------") # a为当前的目录 # b为当前目录下目录 # c为当前目录下的文件
二、fnmatch模块介绍
# 7、查找文件 # 使用fnmatch来查找特定的文件,大部分情况下,使用字符串匹配查找特定的文件就能满足需求,如果需要更加灵活的字符串匹配,可以使用标准库中的fnmatch库,这个库 # 专门用来进行文件名匹配,支持使用通配符进行文件名的匹配
1、fnmatch支持的通配符如下
# fnmatch支持的通配符如下 # * 匹配任何数量的字符 # ? 匹配单个字符 # [sep] 匹配sep中的字符 # [!sep] 匹配除了sep以为的任何字符
2、fnmatch的常用方法介绍
# fnmatch常用的方法 # fnmatch.fnmatch() 判断文件名是否符合特定的模式,区分大小写 # fnmatch.fnmatchcase() 判断文件名是否符合特定的模块,不区分大小写 # fnmatch.filter() 返回输入列表中,符合特定模式的文件名列表 # fnmatch.translate() 将通配符匹配模式转换成正则表达式
3、fnmatch.fnmatch方法介绍
for file in os.listdir("."): if fnmatch.fnmatch(file,"*.html"): print(file) elif fnmatch.fnmatch(file,"[a-z]??.py"): print(file,"hahah") elif fnmatch.fnmatch(file,"[!a-o]*"): print(file) else: pass
4、fnmatch.filter方法介绍
# filter方法和fnmatch一样,只是filer需要传递一个文件的列表进行,返回一个符合匹配规则的列表 print(fnmatch.filter(os.listdir("."),"*py"))
原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/20764.html