百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

14《Python 办公自动化教程》os 模块操作文件与文件夹

wptr33 2025-06-15 19:47 25 浏览

在日常工作中,我们经常会和文件、文件夹打交道,比如将服务器上指定目录下文件进行归档,或将爬虫爬取的数据根据时间创建对应的文件夹 / 文件,如果这些还依靠手动来进行操作,无疑是费时费力的,这时候 Python 中的 os 模块就必不可少了。本小节将围绕 os 模块的使用进行介绍。

1. os 模块介绍

os 模块是 Python 中的内置模块,无需安装即可使用,os 模块提供非常丰富的方法用来处理文件和目录。

os 模块的使用步骤如下:

步骤 1:导入 os 模块

import os

步骤 2:操作文件或者文件夹

通过 os 模块提供的方法对文件、文件夹进行操作

2. os 模块操作文件与文件夹

os 模块是 Python 中操作文件与文件夹时常用的模块,os 模块中常用方法见下表。

方法名

描述

getcwd()

获取当前工作目录

listdir(path)

获取指定的文件夹包含的文件或文件夹的名字的列表

rename(src,dst)

用于文件或文件夹重命名

makedirs(path)

用于递归创建文件夹

removedirs(path)

用于递归删除文件夹

remove(path)

删除指定路径的文件

open(file, flags[, mode])

打开文件

read(fd,n)

读取指定文件

wirte(fd,str)

写入内容

walk(dir)

文件、目录遍历器

os.path 模块中常用方法见下表。

方法名

描述

os.path.exists(path)

如果路径 path 存在,返回 True;如果路径 path 不存在,返回 False

os.path.join(path1[, path2[, …]])

把目录和文件名合成一个路径

下面来具体看下每个方法的使用:

  1. getcwd () 使用:
import os
print(os.getcwd()) #输出:D:\code

代码解释:当前代码文件存放在 D:\code 下,导入 OS 模块,使用 getcwd () 方法,获取当前工作目录,打印结果为 “D:\code”,如下图所示。

  1. listdir () 使用:
import os
print(os.listdir('.'))
#输出:['dingding.py', 'image', 'index.py', 'writeppt.py', 'writeword.py']

代码解释:listdir () 方法可以获取指定的文件夹包含的文件或文件夹的名字的列表,目前 D:\code 目录下文件结构如下图所示。

通过 listdir () 方法传递指定目录,代码中传递 “.” 表示当前目录,输出结果:[‘dingding.py’, ‘image’, ‘index.py’, ‘writeppt.py’, ‘writeword.py’],如下图所示。

  1. rename () 使用:
import os
os.rename("image","newimage")
os.rename("dingding.py","newdingding.py")

代码解释 :rename () 方法为重命名文件或文件夹,第一个参数为要重命名的文件名或文件夹名,第二个参数为修改后的名称,上述代码中将文件夹 “image” 重名为 “newimage”,将文件 “dingding.py” 重名为 “newdingding.py”,代码执行完成后,D:\code 目录下效果如下图所示。

  1. makedirs () 使用:
import os
os.makedirs("dist/src/code")

代码解释:makedirs () 方法用于递归创建目录,参数即为需要递归创建的目录,上述代码指定 “dist/src/code”,即表示创建一个 dist 文件夹,其中包含 src 文件夹,在 src 下包含 code 文件夹。代码执行完成后,D:\code 目录下效果如下图所示。

  1. removedirs () 使用:
import os
os.removedirs("dist/src/code")
print(os.listdir('.'))
#输出:['newdingding.py', 'newimage', 'index.py', 'writeppt.py', 'writeword.py']

代码解释 :removedirs () 方法用于递归删除目录,参数为要递归删除的目录,上述代码指定 “dist/src/code”,即将 dist 文件夹下 src 文件夹下 code 文件夹一并进行删除。执行完删除后,通过 listdir () 方法查看当前目录下文件结构,输出 [‘newdingding.py’, ‘newimage’, ‘index.py’, ‘writeppt.py’, ‘writeword.py’],可以看到已经完成删除操作。代码执行完成后,D:\code 目录下效果如下图所示。

  1. remove () 使用:
import os
os.remove("newdingding.py")
print(os.listdir('.'))
#输出:['newimage', 'index.py', 'writeppt.py', 'writeword.py']

代码解释 :remove () 方法用于删除指定文件,上述代码中删除 “newdingding.py” 文件,删除完成后,通过 listdir () 方法查看当前目录文件结构,输出 [‘newimage’, ‘index.py’, ‘writeppt.py’, ‘writeword.py’],可以看到已经完成删除操作。代码执行完成后,D:\code 目录下效果如下图所示。

  1. open () 使用:
import os
os.open("writeppt.py",os.O_RDONLY)

代码解释:open () 方法用于打开指定文件,第一个参数为要打开的文件,第二个参数为打开的模式,可以取值如下所示:

  • OS.O_RDONLY:以只读的方式打开;
  • OS.O_WRONLY:以只写的方式打开;
  • OS.O_RDWR:以读写的方式打开;
  • OS.O_NONBLOCK:打开时不阻塞;
  • OS.O_APPEND:以追加的方式打开;
  • OS.O_CREAT:创建并打开一个新文件;
  • OS.O_TRUNC:打开一个文件并截断它的长度为零(必须有写权限);
  • OS.O_EXCL:如果指定的文件存在,返回错误;
  • OS.O_SHLOCK:自动获取共享锁;
  • OS.O_EXLOCK:自动获取独立锁;
  • OS.O_DIRECT:消除或减少缓存效果;
  • OS.O_FSYNC:同步写入;
  • OS.O_NOFOLLOW:不追踪软链接。

上述代码中,打开 writeppt.py 文件,以只读方式打开,返回新打开文件的描述符,可以进行后续的读取、写入操作。

  1. read () 使用:
import OS
fs=os.open("writeppt.py",OS.O_RDONLY) # fs 就是 writeppt.py 的文件描述符
print(OS.read(fs,24))

代码解释 :read () 方法为从文件描述符中读取文件内容,第一个参数为 open () 方法打开文件返回的文件描述符,第二个参数为读取的字节数。上述代码中读取 writeppt.py 文件 24 个字节内容。代码执行完成后,输出效果如下图所示。

  1. write () 使用:
import os
fs=os.open("test.txt",os.O_RDWR) # fs 就是 test.txt 的文件描述符,打开模式设置为以读写的方式打开
print(os.write(fs,"hello python")) #写入内容为hello python

代码解释:write () 方法用于写入字符串到文件描述符 fs 中,第一个参数为文件描述符,第二个参数为写入的字符串内容。代码执行完成后,输出效果如下图所示。

  1. walk () 使用:
import os
for dirpath, dirnames, filenames in os.walk("D:/code"):
    #输出:D:/code  ['newimage'] ['index.py','test.txt','writeppt.py','writeword.py']
    print(dirpath, dirnames, filenames)

代码解释:os.walk () 方法是一个简单易用的文件、目录遍历器,接收参数为要遍历的目录的地址,返回的是一个三元组 (dirpath, dirnames, filenames),分别表示当前正在遍历的这个文件夹的本身的地址、该文件夹中所有的目录的名字、该文件夹中所有的文件。代码中指定目录 D:/code,执行时会遍历 D 盘 code 目录下所有文件和文件夹,输出效果如下图所示。

  1. os.path.exists () 使用:
import os
print(os.path.exists("D:\\code\\index.py")) #输出true
print(os.path.exists("D:\\code\\test.py")) #输出False

代码解释 :exists () 方法判断路径是否存在,上面代码中在 D 盘 code 文件夹下存在 index.py,所以输出 true,不存在 test.py,输出 False。代码执行完成后,输出效果如下图所示。

  1. os.path.join () 使用:
import os
#输出D:\code\2020\11
print(os.path.join("D:\\code\\","2020\\","11"))

代码解释:join () 方法用于把目录和文件名合成一个路径。代码执行完成后,输出效果如下图所示。

3. os 模块实战

在开发中,程序遇到异常情况时需要记录错误日志文件,为便于程序员调试,通常错误日志文件的目录结构为:当前年的文件夹下 / 当前月的文件夹下 / 当前日的文件夹 / 具体的 txt 错误日志文件。这时可以使用 Python 的 os 模块封装创建日志的公共方法,完成需求如下:

  1. 根据传入的时间创建对应的年、月、日文件夹,在创建前需要判断文件夹是否存在,存在则不作操作
  2. 根据传入的内容,创建 txt 错误日志文件,当重复调用时,txt 错误日志文件内容为追加

根据上述需求背景,封装后的代码如下:

import os
import datetime

# 获取到当前年
year_time = datetime.datetime.now().year
# 获取到当前月
month_time = datetime.datetime.now().month
# 获取到当前日
daytime = datetime.datetime.now().day

# 生成错误日志文件
def createError(message):
    path = os.getcwd()+"\\"+str(year_time)+"\\"+str(month_time)+"\\"+str(daytime)
    # 文件路径是否存在
    ispath = os.path.exists(path)
    # 判断文件是否存在:不存在创建
    if not ispath:
        os.makedirs(path)
    # 写入异常到错误日志文件(log.txt)
    writeError(path, message)
# 写入异常到错误日志文件
def writeError(path, message):
    fs = os.open(path+"\\log.txt", os.O_RDWR | os.O_CREAT)
    os.write(fs, message.encode('utf-8'))
# 模拟调用
createError("SQL语句异常")

代码解释:代码中封装了两个方法分别为 createError () 方法和 writeError () 方法,用于生成错误日志存放文件夹及像 log.txt 写入错误日志内容。年月日文件夹使用 datetime 模块获取当前系统的年、月、日,使用 exists () 方法判断指定路径是否存在,返回布尔值,存在则返回 true。

如果不存在则通过 os 模块下的 makedirs () 方法进行创建。文件夹创建完成后,调用 writeError () 方法写入错误内容,首先使用 open () 方法打开 log.txt 文件,打开模式设置为读写和创建,通过 write () 方法写入错误内容到 log.txt。代码执行完成后,输出效果如下图所示:

4. 小结

本节课程我们主要学习了 os 模块的使用。本节课程的重点如下:

  • 了解 os 模块作用及使用步骤;
  • 掌握 os 模块中操作文件与文件夹的使用方法。

相关推荐

什么是Java中的继承?如何实现继承?

什么是继承?...

Java 继承与多态:从基础到实战的深度解析

在面向对象编程(OOP)的三大支柱中,继承与多态是构建灵活、可复用代码的核心。无论是日常开发还是框架设计,这两个概念都扮演着至关重要的角色。本文将从基础概念出发,结合实例与图解,带你彻底搞懂Java...

Java基础教程:Java继承概述_java的继承

继承概述假如我们要定义如下类:学生类,老师类和工人类,分析如下。学生类属性:姓名,年龄行为:吃饭,睡觉老师类属性:姓名,年龄,薪水行为:吃饭,睡觉,教书班主任属性:姓名,年龄,薪水行为:吃饭,睡觉,管...

java4个技巧:从继承和覆盖,到最终的类和方法

日复一日,我们编写的大多数Java只使用了该语言全套功能的一小部分。我们实例化的每个流以及我们在实例变量前面加上的每个@Autowired注解都足以完成我们的大部分目标。然而,有些时候,我们必须求助于...

java:举例说明继承的概念_java继承的理解

在现实生活中,继承一般指的是子女继承父辈的财产。在程序中,继承描述的是事物之间的所属关系,通过继承可以使多种事物之间形成一种关系体系。例如猫和狗都属于动物,程序中便可以描述为猫和狗继承自动物,同理,...

从零开始构建一款开源的 Vibe Coding 产品 Week1Day4:业界调研之 Agent 横向对比

前情回顾前面两天我们重点调研了了一下Cursor的原理和Cursor中一个关键的工具edit_file的实现,但是其他CodingAgent也需要稍微摸一下底,看看有没有优秀之处,下...

学会这几个插件,让你的Notepad++使用起来更丝滑

搞程序开发的小伙伴相信对Notepad++都不会陌生,是一个占用空间少、打开启动快的文件编辑器,很多程序员喜欢使用Notepad++进行纯文本编辑或者脚本开发,但是Notepad++的功能绝不止于此,...

将 node_modules 目录放入 Git 仓库的优点

推荐一篇文章Whyyoushouldcheck-inyournodedependencies[1]...

再度加码AI编程,腾讯发布AI CLI并宣布CodeBuddy IDE开启公测

“再熬一年,90%的程序员可能再也用不着写for循环。”凌晨两点半,王工还在公司敲键盘。他手里那份需求文档写了足足六页,产品经理反复改了三次。放在过去,光数据库建表、接口对接、单元测试就得写两三天。现...

git 如何查看stash的内容_git查看ssh key

1.查看Stash列表首先,使用gitstashlist查看所有已保存的stash:...

6万星+ Git命令懒人必备!lazygit 终端UI神器,效率翻倍超顺手!

项目概览lazygit是一个基于终端的Git命令可视化工具,通过简易的TUI(文本用户界面)提升Git操作效率。开发者无需记忆复杂命令,即可完成分支管理、提交、合并等操作。...

《Gemini CLI 实战系列》(一)Gemini CLI 入门:AI 上命令行的第一步

谷歌的Gemini模型最近热度很高,而它的...

deepin IDE新版发布:支持玲珑构建、增强AI智能化

IT之家8月7日消息,深度操作系统官方公众号昨日(8月6日)发布博文,更新推出新版deepin集成开发环境(IDE),重点支持玲珑构建。支持玲珑构建deepinIDE在本次重磅更...

狂揽82.7k的star,这款开源可视化神器,轻松创建流程图和图表

再不用Mermaid,你的技术文档可能已经在悄悄“腐烂”——图表版本对不上、同事改完没同步、评审会上被一句“这图哪来的”问得哑口无言。这不是危言耸听。GitHub2025年开发者报告显示,63%的新仓...

《Gemini CLI 实战系列》(五)打造专属命令行工具箱

在前几篇文章中,我们介绍了GeminiCLI的基础用法、效率提升、文件处理和与外部工具结合。今天我们进入第五篇...