pathlib 是Python內建函式庫,Python 文件給它的定義是 Object-oriented filesystem paths(物件導向的檔案系統路徑)。 pathlib 提供表示檔案系統路徑的類,其語意適用於不同的作業系統。
路徑類別在純路徑之間劃分,純路徑提供純粹的計算操作而沒有 I / O,以及具體路徑,它繼承純路徑但也提供 I / O 操作。
#Path.iterdir() # 遍歷目錄的子目錄或者檔案
Path.is_dir() # 判斷是否為目錄
Path.glob () # 過濾目錄(返回生成器)
Path.resolve() # 傳回絕對路徑
Path .exists() # 判斷路徑是否存在
Path.open() # 開啟檔案(支援with)
Path.unlink() # 刪除檔案或目錄(目錄非空觸發例外)
Path.parts # 分割路徑類似os.path.split(), 不過回傳元組
Path. drive # 傳回磁碟機名稱
Path.root # 返迴路徑的根目錄
Path.anchor # 自動判斷回傳drive或root
#Path.parents # 傳回所有上級目錄的清單
Path.with_name() # 更改路徑名稱, 更改最後一層路徑名稱
Path.with_suffix() # 更改路徑後綴
joinpath() # 拼接路徑
relative_to() # 計算相對路徑
match() # 測試路徑是否符合pattern
is_dir () # 是否為檔案
is_absolute() # 是否為絕對路徑
is_reserved() # 是否為預留路徑
exists() # 判斷路徑是否真實存在
cwd() # 傳回目前目錄的路徑物件
home() # 傳回目前使用者的home路徑物件
stat() # 返迴路徑資訊,同os.stat()
chmod() # 更改路徑權限, 類似os.chmod()
expanduser() # 展開~傳回完整路徑物件
mkdir() # 建立目錄
rename() # 重新命名路徑
rglob() # 遞歸遍歷所有子目錄的檔案
getcwd() 方法可以直接取得目前檔案路徑
os.path.dirname(__file__) 取得目前檔案路徑,因為Python 並沒有提供__file__ 這個概念,他是Pycharm 提供的:
import os print(os.getcwd()) # C:\Users\bobin.yang\PycharmProjects\untitled print(os.path.dirname(__file__)) # C:/Users/bobin.yang/PycharmProjects/untitled在pathlib 模組中,透過
Path.cwd() 方法可以直接取得目前檔案路徑,我們可以動手試試看:
import pathlib print(pathlib.Path.cwd()) # C:\Users\bobin.yang\PycharmProjects\untitled透過Pycharm 我們可以使用快速鍵
ctrl 滑鼠左鍵點擊查看該方法的詳細介紹。
cwd() 方法不過是對os 函式庫中
getcwd() 方法進行了封裝,看起來好像更差勁了,但是官方的推出一定不是子虛烏有的,現在就讓我們一起來揭秘。
import os print(os.path.dirname(os.path.dirname(os.getcwd()))) # C:\PycharmProjects在pathlib 函式庫中,可以透過這樣簡潔方法實作:
import pathlib print(pathlib.Path.cwd().parent) # C:\PycharmProjects而且,如果你需要找他爺爺,是不是再來一個
.parent 就行了。相比較 os 模組的
os.path.dirname() 是不是方便太多太多了?
import os print(os.path.join(os.path.dirname(os.getcwd()), '路径拼接', '真麻烦')) # C:\PycharmProjects\路径拼接\真麻烦當你使用pathlib 的時候,我們就一起來感受他的便捷之處吧!
# /Users/mac/test.py import os paths = ('路径拼接', '真麻烦') print(pathlib.Path.cwd().parent.joinpath(*paths)) # C:\PycharmProjects\路径拼接\真麻烦
通过 pathlib 库拼接路径,你可以很方便的调节他在他祖辈的位置,妙哉。
pathlib 封装了很多的 os.path 中的方法,如下所示:
os.path.expanduser() --> pathlib.Path.home()
os.path.expanduser() --> pathlib.Path.expanduser()
os.stat() --> pathlib.Path.stat()
os.chmod() --> pathlib.Path.chmod()
上一节的操作大部分都是通过 pathlib 库中的 Path 实现,其实他还有一个更加高大上的模块,也就是我们这一节的主角:pathlib.PurePath
。
PurePath 是一个纯路径对象,纯路径对象提供了实际上不访问文件系统的路径处理操作。
有三种方法可以访问这些类,我们也称之为 flavor 。
下面让我们来实现一个神奇的功能,判断当前的路径下是否有符合'*.py'规则的文件。
import pathlib print(pathlib.PurePath(__file__).match('*.py')) # True
输出为什么会是 True
呢?因为当前文件夹下不就有一个 test.py
吗?
看见 pathlib.PurePath 后面跟着 match,那是不是能说明他是个对象,而不是一个单纯的路径字符串,因此我们可以试着打印 pathlib.PurePath 看一看。
import pathlib os_path = os.path.dirname(__file__) print(os_path) # C:/PycharmProjects/untitled pure_path = pathlib.PurePath(__file__) print(pure_path) # C:\PycharmProjects\untitled\run.py print(type(pure_path)) # <class 'pathlib.PureWindowsPath'> print(pathlib.PurePath(__file__).match('*.py')) # True
通过打印 os.path 获取当前路径的结果,得到一个路径字符串;而通过 pathlib.PurePath 则获得了一个 PurePosixPath 对象,并且由此得到的路径包括了当前文件 run.py。
以上是Python檔案系統模組pathlib函式庫怎麼使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!