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、拆分路径的方法介绍 # 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、构建路径的方法介绍 # 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、获取文件属性 # os.path模块也包含了若干函数用来获取文件的属性,包括文件的创建时间,修改时间,文件的大小,访问时间 # os.path.getatime() 返回文件的访问的时间 # os.path.getmtime() 返回文件的修改的时间 # os.path.getctime() 返回文件的创建时间 # os.path.getsize() 返回文件的大小
# 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、文件和目录的操作 # os模块保留文件和目录的操作函数,包括创建目录,删除目录,删除文件,重命名文件等 # os.remove() 删除path路径所指向的文件 # os.rmdir() 删除path路径锁指向的文件夹,该文件夹必须为空,否则会报失败 # os.mkdir() 创建一个文件夹 # os.rename() 重命名一个文件或者文件夹
# 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、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为当前目录下的文件
# 8、查找文件 # 使用fnmatch来查找特定的文件,大部分情况下,使用字符串匹配查找特定的文件就能满足需求,如果需要更加灵活的字符串匹配,可以使用标准库中的fnmatch库,这个库 # 专门用来进行文件名匹配,支持使用通配符进行文件名的匹配
# fnmatch支持的通配符如下 # * 匹配任何数量的字符 # ? 匹配单个字符 # [sep] 匹配sep中的字符 # [!sep] 匹配除了sep以为的任何字符
# fnmatch常用的方法 # fnmatch.fnmatch() 判断文件名是否符合特定的模式,区分大小写 # fnmatch.fnmatchcase() 判断文件名是否符合特定的模块,不区分大小写 # fnmatch.filter() 返回输入列表中,符合特定模式的文件名列表 # fnmatch.translate() 将通配符匹配模式转换成正则表达式
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
# filter方法和fnmatch一样,只是filer需要传递一个文件的列表进行,返回一个符合匹配规则的列表 print(fnmatch.filter(os.listdir("."),"*py"))
以上就是python os模块和fnmatch模块的使用介绍的详细内容,更多关于python os模块和fnmatch模块的资料请关注小牛知识库其它相关文章!
fnmatch 模块主要用于文件名称的匹配,其能力比简单的字符串匹配更强大,但比使用正则表达式相比稍弱。。如果在数据处理操作中,只需要使用简单的通配符就能完成文件名的匹配,则使用 fnmatch 模块是不错的选择。 fnmatch 模块中,常用的函数及其功能如表 1 所示。 Python fnmatch模块常用函数及功能 函数名 功能 fnmatch.filter(names, pattern)
本文向大家介绍node.js中http模块和url模块的简单介绍,包括了node.js中http模块和url模块的简单介绍的使用技巧和注意事项,需要的朋友参考一下 前言 本文主要给大家介绍了关于node.js中http模块与url模块的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。 一、http模块的简单介绍 node.js当中的http内置模块可以用于创建http服务
目录表 简介 使用sys模块 字节编译的.pyc文件 from..import语句 模块的__name__ 使用模块的__name__ 制造你自己的模块 创建你自己的模块 from..import dir()函数 使用dir函数 概括 简介 你已经学习了如何在你的程序中定义一次函数而重用代码。如果你想要在其他程序中重用很多函数,那么你该如何编写程序呢?你可能已经猜到了,答案是使用模块。模块基本上就
如何使用web3j为Java应用或Android App增加以太坊区块链支持,本教程内容即涉及以太坊中的核心概念,例如账户管理包括账户的创建、钱包创建、交易转账,交易与状态、智能合约开发与交互、过滤器和事件等,同时也详细说明如何使用web3j提供的API开发接口与以太坊进行交互,是java和android(安卓)工程师学习以太坊应用开发(DApp)的不二选择。 以太坊概述 以太坊是备受关注的区块链
beego 正在逐步的走向乐高模式,也就是把系统逐步的模块化,让一个一个的模块成为乐高的积木,用户可以把这些积木搭建成自己想要的东西,这个就是目前 beego 的发展方向,beego 1.0 版本起包含下面这些模块,这些模块都是我们平常开发过程中非常有用的: session 模块 cache 模块 logs 模块 httplib 模块 context 模块 toolbox 模块 config 模块
author: Wuxiaolong 在Python中有一些内置的数据类型,比如int, str, list, tuple, dict等。Python的collections模块在这些内置数据类型的基础上,提供了几个额外的数据类型:namedtuple, defaultdict, deque, Counter, OrderedDict等,其中defaultdict和namedtuple是两个很实用