在日常编码中,常常会有这种操作,
在当前目录下(用户目录下)新建
一个文件,需要获取一个文件的所在目录
(父目录)等,这些都涉及路径操作,
相信大家都有使用过os.path
处理过,
这个"谁用谁知道"
今天的主角pathlib
才是路径操作的利器。
pathlib
是跨平台的、面向对象的路径操作库,pathlib
就是对os.path
进行了封装,提供了一个便捷的,面向对象的操作方式,
相对os.path
作为string对象众多繁琐的操作,
它才真正是for humans
python3.4+版本标准库支持
python2(2.6/2.7)版本作为第三方库
官方地址https://pathlib.readthedocs.io/en/pep428/
os.path
实现
import os
pwd = os.getcwd()
#当前文件的父路径
father_path = os.path.abspath(os.path.dirname(pwd)+os.path.sep+".")
#当前文件的前两级目录
grandfather_path = os.path.abspath(os.path.dirname(pwd)+os.path.sep+"..")
pathlib
实现
import pathlib
pwd = pathlib.Path.cwd()
pwd.parent
pwd.parent.parent
import pathlib
pathlib.Path.home()
pathlib.Path.cwd()
对于一个跨平台的程序,如果需要在用户目录(当前目录)下的新建文件,
用pathlib
无需去理会平台路径分隔符的差异了(windows
为\
,Unix
为/
)
import pathlib
cwd = pathlib.Path.cwd()
file_path = cwd / 'my.conf'
file_path = cwd.joinpath('my.conf')
创建路径
file_path.name # 获取文件名
file_path.suffix # 获取文件后缀
file_path.anchor # 获取顶级目录
file_path.root # 获取根
file_path._parts # 路径分块组合
pathlib其他属性
import pathlib
cwd_path = pathlib.Path.cwd()
file_path = cwd_path / 'my.conf'
file_path.write_text("debug = 1\n")
with file_path.open(mode='r') as fd:
for line in fd:
print(line)
print(file_path.read_text())
文件操作
file_path.replace(file_path.with_name('your.conf'))
file_path.replace(file_path.with_suffix('.py'))
重命名
import pathlib
import collections
collections.Counter(p.suffix for p in pathlib.Path.cwd().iterdir())
分类统计文件数
import pathlib
def tree(directory):
print(f'- {directory}')
for path in sorted(directory.rglob('*')):
depth = len(path.relative_to(directory).parts)
spacer = ' ' * depth
print(f'{spacer}+ {path.name}')
tree(pathlib.Path.cwd())
目录树
from datetime import datetime
directory = pathlib.Path.cwd()
time, file_path = max((f.stat().st_mtime, f) for f in directory.iterdir())
print(datetime.fromtimestamp(time), file_path)
最后修改文件
下面的是我的公众号二维码图片,欢迎关注我。