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

详细介绍Python中的文件操作库有哪些?

itomcoil 2025-05-15 18:23 13 浏览

在之前的分享中,我们介绍了关于Python文件操作的内容,这些文件操作的内容其实不依赖于外部的库的,全部都是在Python的内置库中完成的,但是在Python中并不只有内置的文件操作库,还提供了一下外部的文件操作库。下面我们就来详细的介绍一下Python中的文件操作库。

内置open()函数

文件操作的核心操作就是利用了Python中的open()函数,这个open()函数是Python标准库的一部分,在使用的时候,我们不需要依赖于外部的安装包,只需要通过open()函数就可以对文件进行打开、读取、写入等操作。如下所示。

file = open('example.txt', 'r')

由于是内建函数,所以不需要第三方依赖模块。

os模块(用于文件和目录操作)

虽然open函数负责文件的打开、读写操作等基本操作,但是Python还是提供了os 模块来提供对于文件或者是目录的更多操作支持,如下所示。

  • os.rename():重命名文件或目录
  • os.remove():删除文件
  • os.mkdir():创建目录
  • os.path 子模块:提供文件路径相关的操作,如 os.path.exists() 检查文件是否存在、os.path.join() 拼接路径等。

具体操作实现如下所示。

import os

# 检查文件是否存在
if os.path.exists('example.txt'):
    print("文件存在")
else:
    print("文件不存在")
    
# 删除文件
os.remove('example.txt')

# 创建一个新目录
os.mkdir('new_directory')

shutil模块(高级文件操作)

如果所上面提到的两种方式是基础的文件操作的话,那么shutil 模块就提供了更高级的文件操作,例如复制、移动文件或目录,以及压缩文件等操作。在日常开发中我们常用到的函数有如下一些。

  • shutil.copy():复制文件
  • shutil.move():移动文件或目录
  • shutil.rmtree():递归删除目录及其内容
  • shutil.make_archive():创建压缩文件

具体实现如下所示。

import shutil

# 复制文件
shutil.copy('example.txt', 'example_copy.txt')

# 移动文件
shutil.move('example.txt', 'new_folder/example.txt')

# 删除整个目录及其内容
shutil.rmtree('old_folder')

# 创建一个压缩文件
shutil.make_archive('archive', 'zip', 'folder_to_compress')

pathlib模块(路径操作)

从Python 3.4 开始,Python通过pathlib 模块开始提供了通过面向对象的方式来实现文件路径处理的方式,通过面向对象的方式使得文件路径操作更加高效简洁,尤其是在面对一些复杂文件路径处理场景的时候,如下所示。

from pathlib import Path

# 创建一个 Path 对象
path = Path('example.txt')

# 检查文件是否存在
if path.exists():
    print("文件存在")
else:
    print("文件不存在")

# 获取文件的父目录
parent_dir = path.parent
print(parent_dir)

# 读取文件内容
content = path.read_text()
print(content)

io模块(处理文件 I/O 操作)

上面我们提到了一个OS模块的内容,这里我们介绍的IO模块,这个模块主要用于对底层文件的操作,例如对于二进制文件对于文本流文件的处理,通过BufferedReaderBufferedWriterTextIOWrapper 等类实现,可以实现更为精确的文件读写行为控制。但是对于一般的文件操作不推荐直接使用IO模块,如下所示。

import io

# 打开文件进行二进制读取
with open('example.txt', 'rb') as file:
    content = file.read()
    print(content)

总结

对于大多数常见的文件操作,open()os 模块已经足够。如果需要更多高级操作,shutilpathlib 提供了更加便利的工具。而 io 模块则用于更细粒度的控制,有兴趣的读者可以深入研究。

相关推荐

selenium(WEB自动化工具)

定义解释Selenium是一个用于Web应用程序测试的工具。Selenium测试直接运行在浏览器中,就像真正的用户在操作一样。支持的浏览器包括IE(7,8,9,10,11),MozillaF...

开发利器丨如何使用ELK设计微服务中的日志收集方案?

【摘要】微服务各个组件的相关实践会涉及到工具,本文将会介绍微服务日常开发的一些利器,这些工具帮助我们构建更加健壮的微服务系统,并帮助排查解决微服务系统中的问题与性能瓶颈等。我们将重点介绍微服务架构中...

高并发系统设计:应对每秒数万QPS的架构策略

当面试官问及"如何应对每秒几万QPS(QueriesPerSecond)"时,大概率是想知道你对高并发系统设计的理解有多少。本文将深入探讨从基础设施到应用层面的解决方案。01、理解...

2025 年每个 JavaScript 开发者都应该了解的功能

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发。1.Iteratorhelpers开发者...

JavaScript Array 对象

Array对象Array对象用于在变量中存储多个值:varcars=["Saab","Volvo","BMW"];第一个数组元素的索引值为0,第二个索引值为1,以此类推。更多有...

Gemini 2.5编程全球霸榜,谷歌重回AI王座,神秘模型曝光,奥特曼迎战

刚刚,Gemini2.5Pro编程登顶,6美元性价比碾压Claude3.7Sonnet。不仅如此,谷歌还暗藏着更强的编程模型Dragontail,这次是要彻底翻盘了。谷歌,彻底打了一场漂亮的翻...

动力节点最新JavaScript教程(高级篇),深入学习JavaScript

JavaScript是一种运行在浏览器中的解释型编程语言,它的解释器被称为JavaScript引擎,是浏览器的一部分,JavaScript广泛用于浏览器客户端编程,通常JavaScript脚本是通过嵌...

一文看懂Kiro,其 Spec工作流秒杀Cursor,可移植至Claude Code

当Cursor的“即兴编程”开始拖累项目质量,AWS新晋IDEKiro以Spec工作流打出“先规范后编码”的系统工程思维:需求-设计-任务三件套一次生成,文档与代码同步落地,复杂项目不...

「晚安·好梦」努力只能及格,拼命才能优秀

欢迎光临,浏览之前点击上面的音乐放松一下心情吧!喜欢的话给小编一个关注呀!Effortscanonlypass,anddesperatelycanbeexcellent.努力只能及格...

JavaScript 中 some 与 every 方法的区别是什么?

大家好,很高兴又见面了,我是姜茶的编程笔记,我们一起学习前端相关领域技术,共同进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力在JavaScript中,Array.protot...

10个高效的Python爬虫框架,你用过几个?

小型爬虫需求,requests库+bs4库就能解决;大型爬虫数据,尤其涉及异步抓取、内容管理及后续扩展等功能时,就需要用到爬虫框架了。下面介绍了10个爬虫框架,大家可以学习使用!1.Scrapysc...

12个高效的Python爬虫框架,你用过几个?

实现爬虫技术的编程环境有很多种,Java、Python、C++等都可以用来爬虫。但很多人选择Python来写爬虫,为什么呢?因为Python确实很适合做爬虫,丰富的第三方库十分强大,简单几行代码便可实...

pip3 install pyspider报错问题解决

运行如下命令报错:>>>pip3installpyspider观察上面的报错问题,需要安装pycurl。是到这个网址:http://www.lfd.uci.edu/~gohlke...

PySpider框架的使用

PysiderPysider是一个国人用Python编写的、带有强大的WebUI的网络爬虫系统,它支持多种数据库、任务监控、项目管理、结果查看、URL去重等强大的功能。安装pip3inst...

「机器学习」神经网络的激活函数、并通过python实现激活函数

神经网络的激活函数、并通过python实现whatis激活函数感知机的网络结构如下:左图中,偏置b没有被画出来,如果要表示出b,可以像右图那样做。用数学式来表示感知机:上面这个数学式子可以被改写:...