Python os, shutil 使用笔记

本文详细介绍了Python的os和shutil模块。os模块提供与操作系统交互的功能,包括os.path文档和更多相关工具。shutil模块则从Python 3.8开始优化了文件拷贝性能,利用平台特定的快速复制系统调用,如macOS的fcopyfile、Linux的os.sendfile和Windows的大缓冲区策略。当快速拷贝失败时,shutil会自动回退到低效但可靠的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. os 模块

  1. os
    文档
函数名描述
os.getcwd()返回当前工作目录
os.rename(src, dst)src和dst要么是dir,要么是filename
os.rmdir(path)删除指定路径
os.listdir(path)返回指定路径下的文件和文件夹
os.walk链接
os.path很多
  1. os.path
    文档
    更多
函数名描述
os.path.isdir(path)判断路径是否为文件夹
os.path.isfile(path)判断路径是否为文件
os.path.abspath(path)返回绝对路径
os.path.exists(path)如果路径 path 存在,返回 True;如果路径 path 不存在,返回 False
os.path.split(path)把路径分割成 dirname 和 basename,返回一个元组
os.path.join(path1[, path2[, …]])把目录和文件名合成一个路径
os.path.walk(path, visit, arg)遍历path,进入每个目录都调用visit函数,visit函数必须有3个参数(arg, dirname, names),dirname表示当前目录的目录名,names代表当前目录下的所有文件名,args则为walk的第三个参数

2. shutil 模块

从 Python 3.8 开始,所有涉及文件拷贝的函数 (copyfile(), copy(), copy2(), copytree()
以及 move()) 将会使用平台专属的 “fast-copy” 系统调用以便更高效地拷贝文件。
macOS 上将会使用fcopyfile 来拷贝文件内容(不含元数据)。
Linux 上将会使用 os.sendfile()
Windows 上shutil.copyfile() 将会使用更大的默认缓冲区(1 MiB 而非 64 KiB)并且会使用基于 memoryview() 的shutil.copyfileobj() 变种形式。
如果快速拷贝操作失败并且没有数据被写入目标文件,则 shutil将在内部静默地回退到使用效率较低的 copyfileobj() 函数。

文档

函数名描述
shutil.copy(src, dst)(src)为完整的原始文件名,(dst)可以是路径或路径+新文件名
shutil.copyfile(src, dst)(src)为文件完整位置,(dst)必须是完整的目标文件名
shutil.copytree(src, dst, symlinks=False, ignore=None)将以 src 为根起点的整个目录树拷贝到名为 dst 的目录并返回目标目录
shutil.move(src, dst)递归地将一个文件或目录 (src) 移至另一位置 (dst) 并返回目标位置
shutil.rmtree(path)删除一个完整的目录树;path 必须指向一个目录(但不能是一个目录的符号链接)
# Python copytree 代码
def copytree(src, dst, symlinks=False):
    names = os.listdir(src)
    os.makedirs(dst)
    errors = []
    for name in names:
        srcname = os.path.join(src, name)
        dstname = os.path.join(dst, name)
        try:
            if symlinks and os.path.islink(srcname):
                linkto = os.readlink(srcname)
                os.symlink(linkto, dstname)
            elif os.path.isdir(srcname):
                copytree(srcname, dstname, symlinks)
            else:
                copy2(srcname, dstname)
            # XXX What about devices, sockets etc.?
        except OSError as why:
            errors.append((srcname, dstname, str(why)))
        # catch the Error from the recursive copytree so that we can
        # continue with other files
        except Error as err:
            errors.extend(err.args[0])
    try:
        copystat(src, dst)
    except OSError as why:
        # can't copy file access times on Windows
        if why.winerror is None:
            errors.extend((src, dst, str(why)))
    if errors:
        raise Error(errors)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值