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

python内置模块pathlib.Path类操作目录和文件

off999 2024-10-12 06:17 53 浏览 0 评论

python自带的pathlib模块提供了很多路径相关的功能,而pathlib.Path 是pathlib 模块中的一个核心类,它代表了文件系统中的一个路径,实现功能比如创建、删除、移动文件,读取和写入文件内容,遍历目录等。

Path 类跟os.path提供的功能有很多相似之处,各有所长,大家可根据实际需要选择os.path或者pathlib.Path。

pathlib.Path路径操作

使用前我们先导入Path类

from pathlib import Path

以下是Path类的源代码介绍,继承自PurePath类,初始化函数支持可变参数,可传可不传。

介绍classmethod,可通过Path类直接调用

Path.cwd(): 返回当前程序工作的目录。

功能类似于os.getcwd()

测试代码:

print(f'当前目录: {Path.cwd()}')
当前目录: /Users/htsc/Desktop

Path.home(): 返回当前程序工作的目录的家目录。

功能类似于os.path.expanduser('~')。

测试代码:

print(f'当前目录的家目录: {Path.home()}')
当前目录的家目录: /Users/htsc

介绍非classmethod,需要初始化Path类然后调用

Path.samefile(other_path): 检查对象是否跟传入的路径是同一个文件或目录。

功能类似于os.path.samefile()。

测试代码:

先初始化Path类,传入参数Path.cwd(),表示当前路径。

path_ins= Path(Path.cwd())
print(path_ins.samefile('/Users/htsc/Desktop'))
结果:
True

Path.iterdir( ): 返回路径下的文件和目录对象,不会递归里面的目录。这个方法返回的是一个生成器,可通过for循环访问。

测试代码:

先初始化Path类,传入参数Path.cwd(),表示当前路径。使用iterdir函数访问目录的内容,并对子目录继续使用iterdir函数访问。

path_ins= Path(Path.cwd())
for i in path_ins.iterdir():
   print(f'第一层路径:{i}')
   if i.is_dir(): #如果有第二层目录,则循环
     for j in i.iterdir():
     print(f'第二层路径:{j}')

Path.glob(pattern): 返回与给定模式匹配的所有文件路径对象;这个方法返回的是一个生成器,可通过for循环访问。

参数pattern解释:pattern是一个字符串,用于指定要搜索的文件模式,有些类似于re模块对应的正则表达式,支持像通配符*,代表单个字符的?等。

以下是一些pattern参数的示例:

  • '*':匹配给定路径下所有的文件和目录(*不会递归查找子目录)。
  • '*.txt':匹配给定路径下所有以.txt结尾的文件(不会递归查找子目录)。
  • 'a/*.csv':匹配a目录下所有以.csv结尾的文件。
  • '**':匹配当前目录及其所有子目录下的文件和目录(**支持递归)。
  • '**/*.py':匹配当前目录及其所有子目录下所有以.py结尾的文件(**支持递归)。
  • '?.txt':匹配所有单个字符文件名并以.txt结尾的文件(例如a.txt,但不包括ab.txt)。
  • '[abc].txt':匹配a.txt、b.txt或c.txt。

测试代码:先初始化Path类,传入参数Path.cwd(),表示当前路径。

1)使用glob函数匹配特定的python文件。

path_ins= Path(Path.cwd())
for i in path_ins.glob('*.py'):
   print(f'路径:{i}')

结果如图:

2)使用glob函数匹配所有的文件和目录。


path_ins= Path(Path.cwd())
for i in path_ins.glob('*'):
   print(f'路径:{i}')


结果如图:

3)使用glob函数匹配当前目录及所有子目录下的所有文件和文件夹。


path_ins= Path(Path.cwd())
for i in path_ins.glob('**'):
   print(f'路径:{i}')

结果如图:

Path.rglob(pattern): 递归遍历所有文件夹,返回与给定模式匹配的所有文件路径对象,这个方法返回的是一个生成器,可通过for循环访问。

rglob函数与glob函数不同之处在于默认会递归所有目录进行匹配。参数pattern与glob函数一致,只是我们不用在传入**来递归了。

测试代码:先初始化Path类,传入参数Path.cwd(),表示当前路径。使用glob函数匹配特定的文件。

path_ins= Path(Path.cwd())
for i in path_ins.rglob('*.py'):
   print(f'路径:{i}')

结果如图:

Path.absolute(): 返回Path对象的绝对路径。

绝对路径=当前程序所在目录+Path对象的参数路径

测试代码:

先初始化Path类,传入1.txt,打印出绝对路径。

path_ins= Path('1.txt')
print(path_ins.absolute())
结果:
/Users/htsc/Desktop/1.txt

Path.is_absolute(): 判断Path对象是否是绝对路径。如果是返回True。

测试代码:

先初始化Path类,传入1.txt,打印是否是绝对路径。

path_ins= Path('1.txt')
print(path_ins.is_absolute())
结果:False

Path.resolve(strict=False): 返回Path对象为绝对路径。如果strict参数=True,则校验Path对象的路径是否正确。

测试代码:

1)初始化时随便写了一个路径,strict参数=True

path_ins= Path('eee/1.txt')
print(path_ins.resolve(strict=True))

执行结果:

2)初始化时随便写了一个路径,strict参数=True

path_ins= Path('eee/1.txt')
print(path_ins.resolve())

执行结果:/Users/htsc/Desktop/eee/1.txt

Path.stat(): 返回文件或目录的状态信息,比如文件大小、创建时间、修改时间等。

该函数功能类似于os.stat()

测试代码:

先初始化Path类,传入真实存在的文件config.txt

path_ins= Path('config.txt')
print(path_ins.stat())

结果:os.stat_result(st_mode=33188, st_ino=6398788, st_dev=16777233, st_nlink=1, st_uid=501, st_gid=20, st_size=81, st_atime=1724491423, st_mtime=1724423868, st_ctime=1724423868)

Path.owner(): 判断Path对象的拥有者

测试代码:

先初始化Path类,传入1.txt,打印owner

path_ins= Path('1.txt')
print(path_ins.owner())
结果:Admin

文件打开/读取/写入相关函数

Path.open(): 类似于open函数,打开文件对象

Path.read_bytes():读取二进制文件内容

Path.read_text(): 读取普通文本内容

Path.write_bytes(data): 以二进制内容写入

Path.wriite_text(data): 以普通文本内容写入

Path.touch(): 默认情况下该方法用于创建一个新的空文件,如果文件已经存在,则会更新其访问和修改时间。

参数exist_ok=False时,则检查传入的路径是否已经存在,已经存在会报错

测试代码:

#初始化时随便写了一个文件名
path_ins= Path('1.txt')
Path_ins.touch()

执行结果:在本地目录新建了一个1.txt的空文件。

Path.mkdir(): 默认情况下该方法用于创建多个新的空文件夹,如果父文件夹或者子文件夹存在时,则报错。

功能类似于os.makedirs()函数

参数exist_ok=True时,则不在检查子文件夹是否已经存在。

参数parents=True时,则不在检查父文件夹是否已经存在。

测试代码:

初始化时随便写了两个文件夹路径
path_ins= Path('2/2')
path_ins.mkdir(parents=True,exist_ok=True)
path_ins.mkdir()

执行结果:在本地目录新建了文件夹2,在文件夹2中又创建了文件夹2,当文件夹存在时最后的语句执行会报错FileExistsError。

Path.rmdir(): 删除空文件夹,如果不是空文件夹则报错,功能类似于os.rmdir()函数

Path.rename(target): 将传入的路径重新命名为目标路径。

测试代码:

先初始化Path类,将config.txt命名为cfg.txt

path_ins= Path('config.txt')
path_ins.rename('cfg.txt')

Path.exits(): 判断路径是否存在。功能类似于os.path.exits(path)

Path.is_file(): 检查路径是否是一个文件。功能类似于os.path.isfile(path)

Path.is_dir(): 检查路径是否是一个目录。功能类似于os.path.isdir(path)

Path.chmod(): 更改目录或文件的权限。功能类似于os.chmod(),这在linux机器上比较常用,在windows下不太常用。

mode权限模式可以使用八进制数(如0o755),由三个部分组成,每个部分表示不同的用户组对文件的权限:文件所有者(Owner)、所属组(Group)、其他用户(Others)。

?文件权限类型?:单个数字最大为4+2+1=7

  • 读(r):值为4,表示可以读取文件内容。
  • 写(w):值为2,表示可以修改文件内容。
  • 执行(x):值为1,表示可以执行该文件或者访问该目录。

?常见权限设置?:

chmod 755:所有者具有读、写、执行权限;所属组和其他用户具有读、执行权限。

chmod 777:所有者,所属组和其他用户都具有读、写、执行权限。

测试代码:

path_ins= Path('config3.txt')
print(path_ins.chmod(0o755))

共勉: 东汉·班固《汉书·枚乘传》:“泰山之管穿石,单极之绠断干。水非石之钻,索非木之锯,渐靡使之然也。”

-----指水滴不断地滴,可以滴穿石头;

-----比喻坚持不懈,集细微的力量也能成就难能的功劳。

----感谢读者的阅读和学习,谢谢大家。

相关推荐

阿里云国际站ECS:阿里云ECS如何提高网站的访问速度?

TG:@yunlaoda360引言:速度即体验,速度即业务在当今数字化的世界中,网站的访问速度已成为决定用户体验、用户留存乃至业务转化率的关键因素。页面加载每延迟一秒,都可能导致用户流失和收入损失。对...

高流量大并发Linux TCP性能调优_linux 高并发网络编程

其实主要是手里面的跑openvpn服务器。因为并没有明文禁p2p(哎……想想那么多流量好像不跑点p2p也跑不完),所以造成有的时候如果有比较多人跑BT的话,会造成VPN速度急剧下降。本文所面对的情况为...

性能测试100集(12)性能指标资源使用率

在性能测试中,资源使用率是评估系统硬件效率的关键指标,主要包括以下四类:#性能测试##性能压测策略##软件测试#1.CPU使用率定义:CPU处理任务的时间占比,计算公式为1-空闲时间/总...

Linux 服务器常见的性能调优_linux高性能服务端编程

一、Linux服务器性能调优第一步——先搞懂“看什么”很多人刚接触Linux性能调优时,总想着直接改配置,其实第一步该是“看清楚问题”。就像医生看病要先听诊,调优前得先知道服务器“哪里...

Nginx性能优化实战:手把手教你提升10倍性能!

关注△mikechen△,十余年BAT架构经验倾囊相授!Nginx是大型架构而核心,下面我重点详解Nginx性能@mikechen文章来源:mikechen.cc1.worker_processe...

高并发场景下,Spring Cloud Gateway如何抗住百万QPS?

关注△mikechen△,十余年BAT架构经验倾囊相授!大家好,我是mikechen。高并发场景下网关作为流量的入口非常重要,下面我重点详解SpringCloudGateway如何抗住百万性能@m...

Kubernetes 高并发处理实战(可落地案例 + 源码)

目标场景:对外提供HTTPAPI的微服务在短时间内收到大量请求(例如每秒数千至数万RPS),要求系统可弹性扩容、限流降级、缓存减压、稳定运行并能自动恢复。总体思路(多层防护):边缘层:云LB...

高并发场景下,Nginx如何扛住千万级请求?

Nginx是大型架构的必备中间件,下面我重点详解Nginx如何实现高并发@mikechen文章来源:mikechen.cc事件驱动模型Nginx采用事件驱动模型,这是Nginx高并发性能的基石。传统...

Spring Boot+Vue全栈开发实战,中文版高清PDF资源

SpringBoot+Vue全栈开发实战,中文高清PDF资源,需要的可以私我:)SpringBoot致力于简化开发配置并为企业级开发提供一系列非业务性功能,而Vue则采用数据驱动视图的方式将程序...

Docker-基础操作_docker基础实战教程二

一、镜像1、从仓库获取镜像搜索镜像:dockersearchimage_name搜索结果过滤:是否官方:dockersearch--filter="is-offical=true...

你有空吗?跟我一起搭个服务器好不好?

来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。昨天闲的没事的时候,随手翻了翻写过的文章,发现一个很严重的问题。就是大多数时间我都在滔滔不绝的讲理论,却很少有涉及动手...

部署你自己的 SaaS_saas如何部署

部署你自己的VPNOpenVPN——功能齐全的开源VPN解决方案。(DigitalOcean教程)dockovpn.io—无状态OpenVPNdockerized服务器,不需要持久存储。...

Docker Compose_dockercompose安装

DockerCompose概述DockerCompose是一个用来定义和管理多容器应用的工具,通过一个docker-compose.yml文件,用YAML格式描述服务、网络、卷等内容,...

京东T7架构师推出的电子版SpringBoot,从构建小系统到架构大系统

前言:Java的各种开发框架发展了很多年,影响了一代又一代的程序员,现在无论是程序员,还是架构师,使用这些开发框架都面临着两方面的挑战。一方面是要快速开发出系统,这就要求使用的开发框架尽量简单,无论...

Kubernetes (k8s) 入门学习指南_k8s kubeproxy

Kubernetes(k8s)入门学习指南一、什么是Kubernetes?为什么需要它?Kubernetes(k8s)是一个开源的容器编排系统,用于自动化部署、扩展和管理容器化应用程序。它...

取消回复欢迎 发表评论: