python中pathlib模塊的基本用法與總結(jié)
前言
相比常用的 os.path而言,pathlib 對于目錄路徑的操作更簡介也更貼近 Pythonic。但是它不單純是為了簡化操作,還有更大的用途。
pathlib 是Python內(nèi)置庫,Python 文檔給它的定義是:The pathlib module – object-oriented filesystem paths(面向?qū)ο蟮奈募到y(tǒng)路徑)。pathlib 提供表示文件系統(tǒng)路徑的類,其語義適用于不同的操作系統(tǒng)。

更多詳細(xì)的內(nèi)容可以參考官方文檔:https://docs.python.org/3/library/pathlib.html#methods
1. pathlib模塊下Path類的基本使用
from pathlib import Path path = r'D:\python\pycharm2020\program\pathlib模塊的基本使用.py' p = Path(path) print(p.name) # 獲取文件名 print(p.stem) # 獲取文件名除后綴的部分 print(p.suffix) # 獲取文件后綴 print(p.parent) # 相當(dāng)于dirname print(p.parent.parent.parent) print(p.parents) # 返回一個iterable 包含所有父目錄 for i in p.parents: print(i) print(p.parts) # 將路徑通過分隔符分割成一個元組
運(yùn)行結(jié)果如下:
pathlib模塊的基本使用.py
pathlib模塊的基本使用
.py
D:\python\pycharm2020\program
D:\python
<WindowsPath.parents>
D:\python\pycharm2020\program
D:\python\pycharm2020
D:\python
D:\
('D:\\', 'python', 'pycharm2020', 'program', 'pathlib模塊的基本使用.py')
- Path.cwd():Return a new path object representing the current directory
- Path.home():Return a new path object representing the user's home directory
- Path.expanduser():Return a new path with expanded ~ and ~user constructs
from pathlib import Path
path_1 = Path.cwd() # 獲取當(dāng)前文件路徑
path_2 = Path.home()
p1 = Path('~/pathlib模塊的基本使用.py')
print(path_1)
print(path_2)
print(p1.expanduser())
運(yùn)行結(jié)果如下:
D:\python\pycharm2020\program
C:\Users\Administrator
C:\Users\Administrator\pathlib模塊的基本使用.py
Path.stat():Return a os.stat_result object containing information about this path
from pathlib import Path
import datetime
p = Path('pathlib模塊的基本使用.py')
print(p.stat()) # 獲取文件詳細(xì)信息
print(p.stat().st_size) # 文件的字節(jié)大小
print(p.stat().st_ctime) # 文件創(chuàng)建時間
print(p.stat().st_mtime) # 上次修改文件的時間
creat_time = datetime.datetime.fromtimestamp(p.stat().st_ctime)
st_mtime = datetime.datetime.fromtimestamp(p.stat().st_mtime)
print(f'該文件創(chuàng)建時間:{creat_time}')
print(f'上次修改該文件的時間:{st_mtime}')
運(yùn)行結(jié)果如下:
os.stat_result(st_mode=33206, st_ino=3659174698076635, st_dev=3730828260, st_nlink=1, st_uid=0, st_gid=0, st_size=543, st_atime=1597366826, st_mtime=1597366826, st_ctime=1597320585)
543
1597320585.7657475
1597366826.9711637
該文件創(chuàng)建時間:2020-08-13 20:09:45.765748
上次修改該文件的時間:2020-08-14 09:00:26.971164
從不同.stat().st_屬性 返回的時間戳表示自1970年1月1日以來的秒數(shù),可以用datetime.fromtimestamp將時間戳轉(zhuǎn)換為有用的時間格式。
Path.exists():Whether the path points to an existing file or directory
Path.resolve(strict=False):Make the path absolute,resolving any symlinks. A new path object is returned
from pathlib import Path
p1 = Path('pathlib模塊的基本使用.py') # 文件
p2 = Path(r'D:\python\pycharm2020\program') # 文件夾
absolute_path = p1.resolve()
print(absolute_path)
print(Path('.').exists())
print(p1.exists(), p2.exists())
print(p1.is_file(), p2.is_file())
print(p1.is_dir(), p2.is_dir())
print(Path('/python').exists())
print(Path('non_existent_file').exists())
運(yùn)行結(jié)果如下:
D:\python\pycharm2020\program\pathlib模塊的基本使用.py
True
True True
True False
False True
True
False
Path.iterdir():When the path points to a directory,yield path objects of the directory contents
from pathlib import Path
p = Path('/python')
for child in p.iterdir():
print(child)
運(yùn)行結(jié)果如下:
\python\Anaconda
\python\EVCapture
\python\Evernote_6.21.3.2048.exe
\python\Notepad++
\python\pycharm-community-2020.1.3.exe
\python\pycharm2020
\python\pyecharts-assets-master
\python\pyecharts-gallery-master
\python\Sublime text 3
Path.glob(pattern):Glob the given relative pattern in the directory represented by this path, yielding all matching files (of any kind),The “**” pattern means “this directory and all subdirectories, recursively”. In other words, it enables recursive globbing.
Note:Using the “**” pattern in large directory trees may consume an inordinate amount of time
遞歸遍歷該目錄下所有文件,獲取所有符合pattern的文件,返回一個generator。
獲取該文件目錄下所有.py文件
from pathlib import Path
path = r'D:\python\pycharm2020\program'
p = Path(path)
file_name = p.glob('**/*.py')
print(type(file_name)) # <class 'generator'>
for i in file_name:
print(i)
獲取該文件目錄下所有.jpg圖片
from pathlib import Path
path = r'D:\python\pycharm2020\program'
p = Path(path)
file_name = p.glob('**/*.jpg')
print(type(file_name)) # <class 'generator'>
for i in file_name:
print(i)
獲取給定目錄下所有.txt文件、.jpg圖片和.py文件
from pathlib import Path
def get_files(patterns, path):
all_files = []
p = Path(path)
for item in patterns:
file_name = p.rglob(f'**/*{item}')
all_files.extend(file_name)
return all_files
path = input('>>>請輸入文件路徑:')
results = get_files(['.txt', '.jpg', '.py'], path)
print(results)
for file in results:
print(file)
Path.mkdir(mode=0o777, parents=False, exist_ok=False)
- Create a new directory at this given path. If mode is given, it is combined with the process' umask value to determine the file mode and access flags. If the path already exists, FileExistsError is raised.
- If parents is true, any missing parents of this path are created as needed; they are created with the default permissions without taking mode into account (mimicking the POSIX mkdir -p command).
- If parents is false (the default), a missing parent raises FileNotFoundError.
- If exist_ok is false (the default), FileExistsError is raised if the target directory already exists.
- If exist_ok is true, FileExistsError exceptions will be ignored (same behavior as the POSIX mkdir -p command), but only if the last path component is not an existing non-directory file.
Changed in version 3.5: The exist_ok parameter was added.
Path.rmdir():Remove this directory. The directory must be empty.
from pathlib import Path p = Path(r'D:\python\pycharm2020\program\test') p.mkdir() p.rmdir()
from pathlib import Path p = Path(r'D:\python\test1\test2\test3') p.mkdir(parents=True) # If parents is true, any missing parents of this path are created as needed p.rmdir() # 刪除的是test3文件夾
from pathlib import Path p = Path(r'D:\python\test1\test2\test3') p.mkdir(exist_ok=True)
- Path.unlink(missing_ok=False):Remove this file or symbolic link. If the path points to a directory, use Path.rmdir() instead. If missing_ok is false (the default), FileNotFoundError is raised if the path does not exist. If missing_ok is true, FileNotFoundError exceptions will be ignored. Changed in version 3.8:The missing_ok parameter was added.
- Path.rename(target):Rename this file or directory to the given target, and return a new Path instance pointing to target. On Unix, if target exists and is a file, it will be replaced silently if the user has permission. target can be either a string or another path object.
- Path.open(mode=‘r', buffering=-1, encoding=None, errors=None, newline=None):Open the file pointed to by the path, like the built-in open() function does.
from pathlib import Path
p = Path('foo.txt')
p.open(mode='w').write('some text')
target = Path('new_foo.txt')
p.rename(target)
content = target.open(mode='r').read()
print(content)
target.unlink()
2. 與os模塊用法的對比

總結(jié)
到此這篇關(guān)于python中pathlib模塊的基本用法與總結(jié)的文章就介紹到這了,更多相關(guān)python pathlib模塊用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 對python3中pathlib庫的Path類的使用詳解
- python3 pathlib庫Path類方法總結(jié)
- Python標(biāo)準(zhǔn)庫pathlib操作目錄和文件
- Python中的pathlib庫使用詳解
- 一文帶你掌握Python中pathlib模塊的用法
- Python pathlib模塊實(shí)例詳解
- python中pathlib 面向?qū)ο蟮奈募到y(tǒng)路徑
- Python文件系統(tǒng)模塊pathlib庫
- Python pathlib模塊使用方法及實(shí)例解析
- Python如何使用pathlib模塊處理文件路徑
- Python中pathlib庫的使用小結(jié)
相關(guān)文章
python轉(zhuǎn)化excel數(shù)字日期為標(biāo)準(zhǔn)日期操作
這篇文章主要介紹了python轉(zhuǎn)化excel數(shù)字日期為標(biāo)準(zhǔn)日期操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07
python3+PyQt5實(shí)現(xiàn)支持多線程的頁面索引器應(yīng)用程序
這篇文章主要為大家詳細(xì)介紹了python3+PyQt5實(shí)現(xiàn)支持多線程的頁面索引器應(yīng)用程序,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-04-04
Python importlib動態(tài)導(dǎo)入模塊實(shí)現(xiàn)代碼
這篇文章主要介紹了Python importlib動態(tài)導(dǎo)入模塊實(shí)現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-04-04
一行代碼實(shí)現(xiàn)Python動態(tài)加載依賴
本文主要介紹了Python動態(tài)加載依賴,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-12-12
Python實(shí)現(xiàn)GB格式序列文件轉(zhuǎn)換Fasta格式文件
這篇文章主要為大家介紹了Python實(shí)現(xiàn)GB格式序列文件轉(zhuǎn)換Fasta格式文件示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07

