6-文件/目录操做

操做文件内容

读取文件

with open(filepath,'r')as f
     f.read()
  1. 调用read()会一次性读取文件的所有内容,若是文件有10G,内存就爆了,
  2. 能够反复调用read(size)方法,每次最多读取size个字节的内容。
  3. 调用readline()能够每次读取一行内容,
  4. 调用readlines()一次读取全部内容并按行返回list。所以,要根据须要决定怎么调用。

写入文件

with open("test.txt",'w',encoding="utf-8")as f:
    f.writelines(["sfsdfsd",'sdfsdfsdf'])
  1. write 写入文件内容
  2. whitelines接收一个列表,写入文件

操做文件

检查文件权限

os.access("tes1t.txt",os.F_OK) # 返回 True or False

一共有如下属性:windows

F_OK
R_OK
W_OK
X_OK

分别是 存在,可读,可写,可执行函数

删除文件

os.remove("test.txt")

若是参数是一个目录路径的话,会报错spa

复制文件

须要引入第三方依赖来进行文件复制unix

shutil.copyfile( src, dst)    #从源src复制到dst中去。固然前提是目标地址是具有可写权限。抛出的异常信息为IOException. 若是当前的dst已存在的话就会被覆盖掉

移动文件

shutil.move( src, dst)        移动文件或重命名
os.rename(src,dst)

操做目录

重命名文件夹

os.rename(path)

建立目录

os.mkdir(path)

移除目录

os.rmdir(path)

遍历目录

os.walk(top, topdown=True, onerror=None, followlinks=False)

参数的含义:code

参数 定义
top 给定的路径
topdown 自上而下搜索
onerror 函数,调用须要传一个参数,OSError实例,出现错误后执行
followelinks 经过软链接进行访问

返回三个值:orm

返回值 意义
dirname 返回文件夹的相对路径
dirpath 返回的是一个集合,是当前遍历到的全部文件夹的集合
filenames 返回的也是一个集合,文件名集合

递归移除目录

shutil.rmtree( src )    递归删除一个目录以及目录内的全部内容

递归建立目录

os.makedirs(path)

路径操做

判断是文件路径仍是目录路径

os.path.isfile(path)
os.path.isdir(path)

判断路径是否存在

os.path.exists(path)

当前路径

os.getcwd()

路径拼接

为何须要路径拼接呢? 由于在 windows 用 来表示路径,而 *unix 使用 / 来表示路径递归

os.path.join(os.getcwd(),"foler")

分离文件和拓展名

os.path.splitext(path)

绝对路径

os.pathp.abspath(path)

获得文件名

os.path.basename(path)

获得目录名

os.path.dirname(path)

打包解压

打包

shutil.make_archive(base_name, format[, root_dir[, base_dir[, verbose[, dry_run[, owner[, group[, logger]]]]]]])

例子:ip

# 打包当前目录
import shutil
shutil.make_archive("test","zip")

解压缩

shutil.unpack_archive(filename[, extract_dir[, format]])

例子内存

# 解压文件到 test 文件夹
shutil.unpack_archive("test.zip","test")

其余

列出目录下的全部文件和目录

os.listdir(path)
相关文章
相关标签/搜索