一文搞定Python操作文件和目录
本文首发于公众号“AntDream”,欢迎微信搜索“AntDream”或扫描文章底部二维码关注,和我一起每天进步一点点
文件和目录操作是很常见的功能,这里做个简单的总结,包括注意事项和实际的实现代码,基本日常开发都够用了
目录操作
判断目录或是文件是否存在
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)
总结
以上就是Python文件和目录操作的常用知识点和方法总结,建议大家收藏起来,以后方便随时查看。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Django配置celery定时任务
安装celery 使用redis+celery的方式(使用的是阿里源,也可以选择不用) pip install -i https://mirrors.aliyun.com/pypi/simple/ -U "celery[redis]" 修改Django的settings配置文件 添加celery文件在app同级目录下添加一个文件夹,例:service_celery 在文件夹中添加celery.py文件,内容如下: #!/usr/bin/env python from __future__ import absolute_import, unicode_literals import os from celery import Celery # set the default Django settings module for the 'celery' program. os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'settings') app = Celery('bank_service') # Using a string her...
- 下一篇
《阿里云前端技术周刊》第十七期
作者:@牧曈(jitong.zjt) 校对:@月七(yueqi.gc) @亦逊(eason.ym) 知乎:阿里云中台前端/全栈团队专栏Github:阿里云前端技术周刊 给我们投稿:传送门参与交流:传送门 前端速报 proposal-optional-chaining 期待已久的两个 ES 提案:Optional Chaining 和 Nullish Coalescing 正式进入 stage3,同时 typescript 将于 3.7 版本对这些特性提供支持。 FileAPI 一组用于文件处理的 JavaScript 工具。 Why I don't use web components 作者从多个角度分析了为什么不使用 Web-Components。 Micro Front-end 微前端。 What’s new in ES2019 一起来看看
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
-
Docker使用Oracle官方镜像安装(12C,18C,19C)
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8编译安装MySQL8.0.19
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
推荐阅读
最新文章
- Mario游戏-低调大师作品
- CentOS7安装Docker,走上虚拟化容器引擎之路
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- CentOS7,CentOS8安装Elasticsearch6.8.6
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- CentOS6,CentOS7官方镜像安装Oracle11G
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- 设置Eclipse缩进为4个空格,增强代码规范