溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

python中pathlib模塊的基本用法與總結(jié)

發(fā)布時(shí)間:2020-09-12 07:15:18 來(lái)源:腳本之家 閱讀:194 作者:葉庭云 欄目:開(kāi)發(fā)技術(shù)

前言

相比常用的 os.path而言,pathlib 對(duì)于目錄路徑的操作更簡(jiǎn)介也更貼近 Pythonic。但是它不單純是為了簡(jiǎn)化操作,還有更大的用途。

pathlib 是Python內(nèi)置庫(kù),Python 文檔給它的定義是:The pathlib module – object-oriented filesystem paths(面向?qū)ο蟮奈募到y(tǒng)路徑)。pathlib 提供表示文件系統(tǒng)路徑的類(lèi),其語(yǔ)義適用于不同的操作系統(tǒng)。

python中pathlib模塊的基本用法與總結(jié)

更多詳細(xì)的內(nèi)容可以參考官方文檔:https://docs.python.org/3/library/pathlib.html#methods

1. pathlib模塊下Path類(lèi)的基本使用

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) # 返回一個(gè)iterable 包含所有父目錄
for i in p.parents:
 print(i)
print(p.parts)  # 將路徑通過(guò)分隔符分割成一個(gè)元組

運(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)建時(shí)間
print(p.stat().st_mtime) # 上次修改文件的時(shí)間
creat_time = datetime.datetime.fromtimestamp(p.stat().st_ctime)
st_mtime = datetime.datetime.fromtimestamp(p.stat().st_mtime)
print(f'該文件創(chuàng)建時(shí)間:{creat_time}')
print(f'上次修改該文件的時(shí)間:{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)建時(shí)間:2020-08-13 20:09:45.765748
上次修改該文件的時(shí)間:2020-08-14 09:00:26.971164

從不同.stat().st_屬性 返回的時(shí)間戳表示自1970年1月1日以來(lái)的秒數(shù),可以用datetime.fromtimestamp將時(shí)間戳轉(zhuǎn)換為有用的時(shí)間格式。

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的文件,返回一個(gè)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('>>>請(qǐng)輸入文件路徑:')
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模塊用法的對(duì)比

python中pathlib模塊的基本用法與總結(jié)

總結(jié)

到此這篇關(guān)于python中pathlib模塊的基本用法與總結(jié)的文章就介紹到這了,更多相關(guān)python pathlib模塊用法內(nèi)容請(qǐng)搜索億速云以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持億速云!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI