python文件及目录操作代码汇总
作者:lc-snail 发布时间:2022-08-19 14:07:27
前言
在python中,内置了文件(file)对象,通过一些内置的方法就可以实现对文件的操作,例如open()方法创建一个文件对象,write()方法向文件写入内容。
一.文件基本操作
1.创建和打开文件
想要操作文件,先要创建或者打开指定文件并创建文件对象,可以通过内置函数open()来实现。
file = open(file_name[,mode[,buffering]])
'''
file_name : 要创建或者打开的文件名
mode : 用于指定文件打开的方式
'''
mode参数的参数值表
模式 | 描述 |
---|---|
r | 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 |
rb | 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。 |
r+ | 打开一个文件用于读写。文件指针将会放在文件的开头。 |
rb+ | 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。 |
w | 打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
wb | 以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
w+ | 打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
wb+ | 以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
a | 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
ab | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
a+ | 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。 |
ab+ | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。 |
注意
采用open()函数打开文件时,默认采用的是GBK编码,如果想要用其他编码方式,需要加上encoding参数
file = open('./text.txt','a+',encoding='utf-8')
#需要采用原文件用的编码方式打开,不然会报错
2.关闭文件
打开文件之后,需要及时关闭,以免对文件造成不必要的破坏。可以用内置函数close()。
file = open('./text.txt','a+')
file.close()
注
close()函数先刷新缓冲区中还没有写入的信息,将其写入到文件中,再关闭文件,起到对文件的保护作用。
3.写入文件
语法
file = write(string)
demo
#打开文件
file = open('./text.txt','a+')
#写入文件
file = write('不负代码,不负卿')
#关闭文件
file.close()
注:
再写入文件的时候要注入打开文件的时候是处于什么模式,不然会把原数据覆盖掉。
4.读取文件
读取文件的前提是在打开文件时,指定的打开模式为r(只读)或者r+(读写)否则,会抛出异常。
(1)读取指定字符
file.read([size])
#size :用于指定要读取的字符个数,如果省略,则一次性读取所有内容。
(2)读取一行
file.readline()
该方法用于读取一行文本
(3)读取全部行
file.readlins()
二.目录操作
python内置了os模块及子模块os.path用于对目录或文件的操作。
os模块提供的与目录相关的函数
函数 | 说明 |
---|---|
getcwd() | 返回当前的工作目录 |
listdir(path) | 返回指定路径下的文件和目录信息 |
mkdir(path[,mode]) | 创建目录 |
makedirs(path/path2.....) | 创建多级目录 |
rmdir(path) | 删除目录 |
removedirs(/path1/path2...) | 删除多级目录 |
chdir(path) | 把path设置为当前工作目录 |
walk(top[,topdown[,onerror]) | 遍历 |
access(path,accessmode) | 获取指定文件是否有某个权限(accessmode的等于R_OK(读取),W_OK(写入),X_OK(执行),F_OK(存在)),如果有指定的权限,返回1,否则返回0. |
chmod(path,mode) | 修改path指定文件的访问权限 |
remove(path) | 删除指定的文件路径 |
rename(src,dst) | 将文件或目录src重命名为dst |
stat(path) | 返回path指定文件的信息 |
os.path模块提供与目录有关的函数
函数 | 说明 |
---|---|
abspath(path) | 用于获取文件或目录的绝对路径 |
exists(path) | 用于判断目录或者文件是否存在,如果存在则返回True,否则返回False |
join(path,name) | 将目录与目录或者文件名拼接起来 |
splitext() | 分离文件名和拓展名 |
split(path) | 将路径和文件名分开 |
basename(path) | 从一个目录中提取文件名 |
dirname(path) | 从一个路径中提取文件路径,不包括文件名 |
isdir(path) | 用于判断路径是否有效 |
demo —— 获取当前工作目录
import os
print(os.getcwd())
demo —— 判断目录是否存在
import os
print(os.path.exists("c:\\demo"))
注
因为exists()是os的子模块提供的,所以要要加前缀,os.path
demo —— 创建一级目录
import os
path = "c://demo"
#如果要创建的目录已经存在,则会抛出异常,先判断要创建的目录是否存在
if not os.path.exists(path):
os.mkdir(path)
else:
print('该目录已经存在')
注
mkdir(path)创建的目录是一级目录,如果传入的path中最后一级的上级目录不存在,那么会抛出异常。
demo —— 创建多级目录
import os
os.makedirs("C:\\demo1\\demo2\\...")
demo —— 删除目录
import os
path = "C:\\demo1\\demo2"
#判断要删除的目录,如果不存在会抛出问题
if os.path.exists(path):
os.rmdir("C:\\demo1\\demo2") #删除的是demo2这个文件
print("目录删除成功!")
else:
print("该目录不存")
注:
rmdir()函数只能删除空的目录,如果不为空就不能删除,可以一下代码删除不为空的目录。
import shutil
shutil.rmtree("C:\\demo\\text")
demo —— 遍历目录
os.walk()的返回值是一个包含三个元素(dirpath,dirnams,filenames)的元组生成器对象。
dirpath: 是一个字符串,表示当前遍历的路径
dirnames: 是一个列表,表示的是当前路径下包含的子目录
filenames: 也是一个列表,当前目录下的文件
os.walk(top,[topdown][,onerror][,followlinks])
'''
top: 用于指定要遍历的目录
topdown: 可选参数,用于指定要遍历的顺序,如果为True(默认),表示从上到下遍历,如果为False,表示从小到上。
'''
import os
path = "C:\\demo"
#root 是当前根路径,dirs包含路径下的子目录,files包含了子目录下的二五年间
for root,dirs,fles in os.walk(path,topdown=True):
for name in dirs:
print(os.path.join(root,name))
for name in files:
print(os.path.join(root.name))
demo —— 产找当前目录下某个文件是否存在
import os
path = "C:\\demo"
filename = "love.txt"
for root,dirs,files in os.walk(path):
for name in files:
if filename== name:
print(os.path.join(root,name))
来源:https://www.cnblogs.com/lc-snail/p/13248709.html
![](https://www.aspxhome.com/images/zang.png)
![](https://www.aspxhome.com/images/jiucuo.png)
猜你喜欢
- Python实现按某一列关键字分组,并计算各列的平均值,并用该值填充该分类该列的nan值。DataFrame数据格式fillna方式实现gr
- 用ASP判断一个字符串中只包含字母和数字要怎么做啊? for s=1 to len(trim(use
- python语言中的列表排序方法有三个:reverse反转/倒序排序、sort正序排序、sorted可以获取排序后的列表。在更高级列表排序中
- 这是一个很简单的纯CSS相册滑动浏览效果,仅用一个无序列表ul结合简单的CSS就可以实现。原文中介绍的纵向滑动相册的实现方法,但是相比之下个
- 目录OpenCV先决条件我们会在本文中涵盖7个主题读,写和显示图像imread():imshow():imwrite():读取视频并与网络摄
- 画一个地球想画一个转动的地球,那么首先要有一个球,或者说要有一个球面,用参数方程可以表示为x=rcosϕcosθy=rc
- 简述Motivationsometimes,换一种获取数据的方式,可以提高数据获取的速度。sometimes,由于预计爬取的数据长度不确定,
- 一、手指触屏,利用touchstart和touchend计算前后滑动距离,判断是上拉还是下滑。二、js中距离:pageY、clientY、o
- 在网上查阅资料,发现很少用Python进行高斯函数的三维显示绘图的,原因可能是其图形显示太过怪异,没有MATLAB精细和直观。回顾一下二维高
- 1.锦短情长为什么选择这个标题,借鉴了一封情书里面的情长纸短,还吻你万千。锦短情长都只谓人走茶凉,怎感觉锦短情长?一提起眼泪汪汪,是明月人心
- 常见的数据增强操作有:按比例放大或缩小图片、旋转、平移、水平翻转、改变图像通道等。1.按比例放大和缩小扩展缩放只是改变图像的尺寸大小。Ope
- 我的PJBlog在从2.7升级的3.0的时候,犹豫了很久。升级到PJBlog3.0就是看中了新增的静态页面功能,但是同时又担心造成博客出现大
- 起步Python3 起,str 就采用了 Unicode 编码(注意这里并不是 utf8 编码,尽管 .py 文件默认编码是 utf8 )。
- 折线图是数据分析中非常常用的图形。其中,折线图主要是以折线的上升或下降来表示统计数量的增减变化的统计图。用于分析自变量和因变量之间的趋势关系
- 本人 python新手,使用的环境是python2.7,勿喷# -*- coding:utf8 -*-import random
- 单例模式(Singleton Pattern) 是一种常用的软件设计模式,该模式的主要目的是确保某一个类只有一个实例存在。当你希望在整个系统
- ARIMA模型ARIMA模型的全称是自回归移动平均模型,是用来预测时间序列的一种常用的统计模型,一般记作ARIMA(p,d,q)。ARIMA
- 最近一直在更新Java新特性和IDEA Tips两个专栏,其他方向内容的动态关注少了。昨天天晚上刷推的时候,瞄到了这个神奇的东西,觉得挺co
- 本文实例讲述了python实现自动登录人人网并访问最近来访者的方法,分享给大家供大家参考。具体方法如下:##-*- coding : gbk
- 今天写一个在windows下批量修改文件名的python脚本,用到文件的遍历。用python进行文件遍历有多种方法,这里列举并说明一下。os