一篇文章搞定Python操作文件与目录
作者:xxq2dream 发布时间:2021-03-25 19:30:58
前言
文件和目录操作是很常见的功能,这里做个简单的总结,包括注意事项和实际的实现代码,基本日常开发都够用了
目录操作
判断目录或是文件是否存在
os.path.exists(path)
判断是否是文件或是目录
# 如果文件或是目录不存在也会返回False
os.path.isfile(path)
os.path.isdir(path)
创建/删除目录
os.mkdir(path)
os.rmdir(path)
得到当前的目录名称
os.path.split(dir_path)[1]
这个方法既简单又实用,比如我们输入一个目录路径:
os.path.split('/usr/projects/project1')[1]
# 输出
project1
# 实际上,上面的代码是分了2步走:
# 第1步:利用os.path.split方法分割路径
os.path.split('/usr/projects/project1')
# 输出
('/usr/projects', 'project1')
# 然后第2步取出第2个结果,也就是当前的目录名字
循环遍历目录
循环遍历目录有2种方式,一种是常规的递归方法,类似下面这样:
def list_file(path):
for file in os.listdir(path):
if os.path.isdir(os.path.join(path, file)):
list_file(os.path.join(path, file))
print(file)
还有一种更好的方式就是用os.walk方法,类似下面这样:
def list_file_by_walk(dir_path):
for home, dirs, files in os.walk(dir_path):
print(home)
print(dirs)
# files中是文件列表
for file_name in files:
print(file_name)
os.walk方法的几个参数简单介绍一下:
home:这个是当前遍历的目录,比如说是 /usr/projects/
dirs:是这个目录(home目录)下面的所有文件夹(也就是子目录)
files:是这个目录(home目录)下所有的文件
所以从上面的参数中可以看出,os.walk方法会逐一地遍历初始目录下面的所有目录和文件
常见的文件操作
跟上面得到目录名类似的是得到文件的后缀
os.path.splitext(file_path)
这个方法如果输入的是文件的路径,比如:
a = '/usr/projects/project1/test.txt'
os.path.splitext(a)
# 输出
('/usr/projects/project1/test', '.txt')
# 所以跟上面类似,我们可以直接拿到文件的后缀
os.path.splitext(a)[1]
文件的全路径
# 需要文件的目录路径和文件名
os.path.join(dir_name, file_name)
这个方法也很有用,因为我们在打开一个文件的时候都需要知道文件的路径
比如在上面循环遍历目录的例子中,我们可以这样打开编辑文件:
def list_file_by_walk(dir_path):
for home, dirs, files in os.walk(dir_path):
print(home)
print(dirs)
# files中是文件列表
for file_name in files:
# 这个file_name只是一个文件名
print(file_name)
# 如果我们需要打开文件进行编辑读写操作,那就需要文件的路径
# 用os.path.join方法就可以快速得到文件路径
file_path = os.path.join(home, file_name)
需要注意的是,不要直接用字符串相加的方式来拼接,这样子会有兼容问题,比如windows上可能路径就是错的了
读写文件
打开文件
with open(file, 'r') as f:
for line in f.readlines():
print line
大家只要记住上面打开文件的格式就行了,也就是这句:
with open(file_path, 打开的模式) as f
# 我们就拿到了文件对象f,可以对文件进行操作了,比如读写等
原因是文件读写是IO操作,需要及时关闭打开的文件,上述with open() as f的方式会自动帮你关闭文件的,免得自己忘记关
文件的打开模式
文件的打开模式有很多种,比如只读、只写、追加模式等等,具体可以见下图:
模式有这么多,掌握常见的几种就可以了,其他的等用到了再去了解。需要注意以下几点:
创建文件,只需要打开一个文件即可:
# 只要这样一句就创建了一个新文件,也就是打开以后关闭文件
with open(new_file, 'w') as f:
需要特别注意的是,以w只写模式打开一个文件后会把原文件的内容清除!所以如果在遍历文件的时候,你想同时修改文件就不能简单的以w只写模式打开了。
在遍历文件的时候想同时修改文件怎么办呢?注意这里说的是修改,比如修改某一行。
修改文件的某一部分
这里举例在遍历文件的时候想修改文件,比如以上面遍历目录文件的例子:
def list_file_by_walk(dir_path):
for home, dirs, files in os.walk(dir_path):
print(home)
print(dirs)
# files中是文件列表
for file_name in files:
# 这个file_name只是一个文件名
print(file_name)
# 如果我们需要打开文件进行编辑读写操作,那就需要文件的路径
# 用os.path.join方法就可以快速得到文件路径
file_path = os.path.join(home, file_name)
# 这个时候我想修改这个文件的内容,要怎么做呢?
需要注意的是,读写模式需要管理文件指针,比较麻烦,写读模式,则会把原先的内容都清除,所以都不适合
一种思路是我先以只读模式打开,然后遍历文件的内容保存起来,比如:
with open(file, 'r') as f:
for line in f.readlines():
print line
# 这里就可以把文件的内容一行行保存起来
# 找到需要修改的行,修改以后保存
保存以后再以只读模式打开文件,写入即可。
另一种思路是我打开原文件的同时,再打开另一个临时文件用于写入,比如这样:
with open(file, 'r') as f, open(cache_file_path, 'w') as w:
for line in f.readlines():
# 中间可以对f文件中的内容进行过滤或是修改
w.write(line)
# 完了以后需要删除原文件,然后把临时文件的名字修改成原来文件的名字即可
这里就顺道引出了,删除和重命名文件的方法
os.remove(file)
os.rename(cache_file_path, file)
总结
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。
来源:https://www.jianshu.com/p/5e62c093bfbb


猜你喜欢
- 来源 | OpenCV学堂作者 | gloomyfish基本思路选择以前我用过Caffe,用过tensorflow,最近
- openpyxl 的用法实例1.1 Openpyxl 库的安装使用openpyxl 模块是一个读写 Excel 2010 文档的 Pytho
- vue.js在生成相关js和css文件的时候,名称是通过HASH的方式进行生成的,但是每次生成的文件基本都是一样的,那么浏览器就会缓存这些文
- 前言读取站点资料数据对站点数据进行插值,插值到规则网格上绘制EOF第一模态和第二模态的空间分布图绘制PC序列关于插值,这里主要提供了两个插值
- 目录1. DeepSource2. Codacy3. SonarQube4. Veracode5. Checkmarx6. Coverity
- 如下所示:arrs=[2,15,48,4,5,6,7,6,4,1,2,3,6,6,7,4,6,8]f=open('test.txt&
- 分支的新建与合并现在让我们来看一个简单的分支与合并的例子,实际工作中大体也会用到这样的工作流程:开发某个网站。为实现某个新的需求,创建一个分
- 首先,这次讲解的tansforms功能,通俗地讲,类似于在计算机视觉流程里的图像预处理部分的数据增强。transforms的原理:说明:图片
- 首先,我们来随便写一个带空格的列表:list1 = ['122','2333','3444'
- 前两天写了一篇《浅谈网站用户粘性的含义》的文章,有些个别网友问可否谈谈怎么样加强用户粘性的问题?虽然对此本人没有系统的理论做以支撑,但是既然
- MybatisPlus处理Mysql的json类型1、在数据库表定义JSON字段;2、在实体类加上@TableName(autoResult
- 下面进行一个高维线性实验假设我们的真实方程是:假设feature数200,训练样本和测试样本各20个模拟数据集num_train,num_t
- 前言django,web开发中,用django-debug-toolbar来调试请求的接口,无疑是完美至极。 可能本人,见识博浅,才说完美至
- 第一步、下载压缩包下载社区版的 MySQL,根据需求下载对应版本,其中有最小安装版本。具体各个版本的区别,可以上网查询,链接MySQL ::
- SQL Server 2005数据库中增加了XML类型,在创建表的时候可以指定某一列为XML类型,示例如下:CREATE TABL
- git 报错信息:OpenSSL SSL_read: Connection was reset, errno 10054Git 中 push
- 本文介绍了linux下如何备份与恢复mysql数据库。数据库备份是非常重要的。如果定期做好备份,这样就可以在发生系统崩溃时恢复数据到最后一次
- <?php //作者:遥远的期待 //QQ:15624575 //算法分析:1、必须是整数序列、2、如果整个序列不全是负数,最大子序列
- Python之所以这么流行,是因为它不仅能够应用于科技领域,还能用来做许多其他学科的研究工具,绘制地图便是其功能之一。今天我们用matplo
- 简介说明本文用示例介绍Vuex的五大核心之一:actions。官网Action | VuexAPI 参考 | Vuexactions概述说明