Python语言的文件及目录访问

简介: Python语言的文件及目录访问

Python语言提供了丰富的文件和目录访问功能,这使得开发者能够方便地进行文件读写、目录遍历、文件属性查询等操作。这些功能主要通过内置的osos.path模块,以及iopathlib等模块来实现。

使用os模块访问文件和目录

os模块提供了很多与操作系统交互的函数,包括文件和目录的访问。

访问目录

· os.listdir(path): 列出指定目录下的所有文件和子目录。

· os.makedirs(name, mode=0o777, exist_ok=False): 创建目录。如果目录已存在且exist_okTrue,则不会抛出异常。

· os.rmdir(path): 删除空目录。

· os.walk(top, topdown=True, onerror=None, followlinks=False): 生成目录树下的文件名,返回一个生成器,对每个目录调用,生成(dirpath, dirnames, filenames)。

访问文件

· os.path.exists(path): 检查文件或目录是否存在。

· os.path.isfile(path): 检查路径是否为文件。

· os.path.isdir(path): 检查路径是否为目录。

· os.path.getsize(path): 返回文件大小,如果文件不存在则引发OSError异常。

使用os.path模块处理路径

os.path模块是os模块的一个子模块,专门用于处理文件路径。

· os.path.join(path1[, path2[, ...]]): 将多个路径组件合并成一个。

· os.path.split(path): 将路径分割成目录和文件名两部分,返回一个元组。

· os.path.basename(path): 返回路径中的文件名。

· os.path.dirname(path): 返回路径中的目录名。

· os.path.abspath(path): 返回指定文件的绝对路径。

· os.path.relpath(path[, start]): 返回从当前目录或指定目录到路径的相对路径。

使用pathlib模块处理路径和文件

pathlib模块提供了面向对象的方式来处理文件系统路径。

· Path.cwd(): 返回当前工作目录。

· Path.home(): 返回用户主目录。

· Path.glob(pattern): 使用通配符模式来查找匹配的文件。

· Path.iterdir(): 迭代目录中的文件和子目录。

· Path.mkdir(mode=0o777, parents=False, exist_ok=False): 创建目录。

· Path.open(mode='r', buffering=-1, encoding=None, errors=None, newline=None): 打开文件并返回文件对象。

· Path.read_text(encoding=None, errors=None): 以文本模式打开文件并返回内容。

· Path.write_text(data, encoding=None, errors=None): 以文本模式打开文件并写入内容。

使用io模块进行文件读写

io模块提供了用于处理输入/输出流的类和函数,通常与文件读写一起使用。

· io.open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None): 打开文件并返回相应的文件对象。

示例

下面是一个简单的示例,展示了如何使用这些模块来访问文件和目录:

python复制代码

 

import os

 

from pathlib import Path

 

 

 

# 使用os模块

 

current_dir = os.getcwd() # 获取当前工作目录

 

print(f"Current directory: {current_dir}")

 

 

 

# 列出目录内容

 

contents = os.listdir('.')

 

print("Directory contents:", contents)

 

 

 

# 检查文件是否存在

 

if os.path.exists('example.txt'):

 

print("File exists.")

 

 

 

# 使用pathlib模块

 

p = Path('.') # 当前目录的Path对象

 

for child in p.iterdir(): # 迭代目录中的每个项

 

print(child)

 

 

 

# 读取文件内容

 

file_path = p / 'example.txt' 

 

if file_path.is_file():

 

content = file_path.read_text()

 

print("File content:", content)

 

 

 

# 写入文件内容

 

file_path.write_text("New content for the file.")

这些模块和函数提供了丰富的功能,使得Python在处理文件和目录时非常灵活和强大。开发者可以根据需要选择

 

相关文章
|
1天前
|
Python
Python如何把脚本编译成可执行exe文件_python脚本编译成可执行文件
Python如何把脚本编译成可执行exe文件_python脚本编译成可执行文件
|
1天前
|
数据采集 数据安全/隐私保护 Python
2024年最新【Python】如何用Python来操作PDF文件,收藏(2),2024年最新阿里p7Python面试题
2024年最新【Python】如何用Python来操作PDF文件,收藏(2),2024年最新阿里p7Python面试题
2024年最新【Python】如何用Python来操作PDF文件,收藏(2),2024年最新阿里p7Python面试题
|
1天前
|
开发工具 Python
2024年最新【Python】关于Python打开文件&&上下文管理器(1),2024华为Python面试真题解
2024年最新【Python】关于Python打开文件&&上下文管理器(1),2024华为Python面试真题解
2024年最新【Python】关于Python打开文件&&上下文管理器(1),2024华为Python面试真题解
|
1天前
|
数据采集 JSON 数据挖掘
2024年利用Python查询IP地址_怎么查python文件中ip地址,2024年最新15个经典面试问题及答案英语
2024年利用Python查询IP地址_怎么查python文件中ip地址,2024年最新15个经典面试问题及答案英语
|
1天前
|
机器学习/深度学习 数据采集 自然语言处理
[python][whl]python模块triton的whl文件下载地址汇总(1)
[python][whl]python模块triton的whl文件下载地址汇总(1)
|
1天前
|
XML 数据格式 Python
python挑出训练集里图片对应的xml文件,方便统计标签框的类别与数目_python 统计voc2007xml中某一类别框个数(1)
python挑出训练集里图片对应的xml文件,方便统计标签框的类别与数目_python 统计voc2007xml中某一类别框个数(1)
|
4天前
|
Python
Python办公自动化|自动整理文件,一键完成!
Python办公自动化|自动整理文件,一键完成!
|
6天前
|
数据挖掘 索引 Python
Python 读写 Excel 文件
Python 读写 Excel 文件
107 0
|
6天前
|
存储 JSON JavaScript
Python中读写(解析)JSON文件的深入探究
Python中读写(解析)JSON文件的深入探究
62 0
|
6天前
|
XML 安全 API
Python读写XML文件:深入解析与技术实现
Python读写XML文件:深入解析与技术实现
65 0