Python進(jìn)行文件路徑處理的模塊詳解
1. 前言
項(xiàng)目運(yùn)行環(huán)境:
- 平臺:Window11
- 語言環(huán)境:Python3.8
- 運(yùn)行環(huán)境1:PyCharm 2021.3
- 運(yùn)行環(huán)境2:Jupyter Notebook 7.3.2
- 框架:PyTorch 2.5.1(CUDA11.8)
2. 文件路徑檢查模塊
我相信很多人和貓貓一樣,從來沒有好好研究過Python的文件路徑。之前對于文件路徑輸出、跳轉(zhuǎn)、完整路徑的知識完全來自于Java和linux。例如./、../ 這樣子,你說可以用嘛,自然是可以的。但是這樣子實(shí)在是太不直觀了,Python作為一個(gè)magical語言,肯定有其他更直觀的文件路徑處理方法。你別說,還真有,今天貓貓就來帶你們看看。
2.1 模塊使用方法
假如你現(xiàn)在想要從一個(gè)文件中拿出一個(gè)東西 或者 把你生成的東西放到一個(gè)文件中,此時(shí)你就必須使用這樣一個(gè)文件路徑模塊了。作用是用來看你需要的東西,它到底在路徑層面怎么放到那一個(gè)文件夾中,或從文件夾中拿出來。
不要說你要看PyCharm旁邊的目錄結(jié)構(gòu)就可以了,貓貓今天被坑了1個(gè)多小時(shí)。因?yàn)榕苌疃葘W(xué)習(xí)的代碼我們都是放在服務(wù)器中跑的,但是寫代碼都是在本機(jī)PyCharm中寫的,因此兩者的目錄結(jié)構(gòu)大概率是不一樣的,一旦不注意就容易和貓貓一樣被坑好幾個(gè)小時(shí),所以每次處理和文件路徑有關(guān)的東西,都建議先用貓貓的模塊做一個(gè)檢查。
2.2 子模塊1:當(dāng)前路徑輸出
from pathlib import Path
# 獲取當(dāng)前腳本所在目錄,并輸出絕對路徑
script_parent = Path(__file__).resolve()
print(f"當(dāng)前腳本目錄完整路徑: {script_parent}")
Path(__file__):創(chuàng)建路徑對象。將當(dāng)前腳本的文件路徑轉(zhuǎn)換為 pathlib.Path 對象。
.resolve():解析為絕對路徑。相對路徑轉(zhuǎn)換為絕對路徑(如 ./script.py → /home/user/project/script.py)。
Path(__file__) # /usr/bin/myscript(符號鏈接路徑) Path(__file__).resolve() # /home/user/project/script.py(實(shí)際路徑)
2.3 子模塊2:路徑跳轉(zhuǎn)
通過前面的模塊,我們就看可以看到自己代碼所在的目錄。現(xiàn)在我們想要實(shí)現(xiàn)路徑的跳轉(zhuǎn),因?yàn)槲覀兛绰窂降谋举|(zhì)就是為了到一個(gè)我們想要的路徑中拿到我們想要的東西,或者將我們的東西送到我們想要的地方去,這都涉及路徑的跳轉(zhuǎn)。路徑跳轉(zhuǎn)分為:父路徑跳轉(zhuǎn)+子路徑跳轉(zhuǎn)。
父路徑跳轉(zhuǎn):
本質(zhì)就是退出當(dāng)前路徑,回到父目錄。
from pathlib import Path
# 獲取當(dāng)前腳本所在目錄的父目錄,并輸出絕對路徑
script_parent = Path(__file__).resolve().parent
print(f"父目錄完整路徑: {script_parent}")
.parent:獲取父目錄。返回路徑的父目錄。若路徑是 /home/user/project/script.py:
Path(__file__).resolve().parent # /home/user/project
子路徑跳轉(zhuǎn):
本質(zhì)就是在當(dāng)前目錄中往下深入,因此就是在目錄路徑后面追加一部分路徑內(nèi)容。
script_dir = Path(__file__).resolve().parent.parent.parent target_dir = script_dir / "Real-ESRGAN-main" / "inputs" target_dir1 = script_dir / "Real-ESRGAN-main"
/:后面跟上想要進(jìn)入的路徑名稱即可,可以一級一級疊加使用
.parent:同樣允許一級一級疊加使用
2.4 子模塊3:根目錄完整路徑展示
def generate_file_tree(directory: str, max_depth: int = 3) -> str:
"""生成帶格式的目錄樹(優(yōu)化遞歸性能)"""
def _tree(path: Path, prefix: str = "", depth=0) -> str:
if depth > max_depth:
return ""
try:
items = sorted(path.iterdir(), key=lambda x: (not x.is_dir(), x.name.lower()))
except PermissionError:
return f"{prefix}└── ?? 權(quán)限不足"
except FileNotFoundError:
return f"{prefix}└── ? 目錄已消失"
contents = []
for index, item in enumerate(items):
is_last = index == len(items) - 1
connector = "└── " if is_last else "├── "
# 文件類型識別
if item.is_symlink():
icon = "??"
suffix = f" -> {item.resolve()}"
elif item.is_dir():
icon = "??"
suffix = ""
else:
icon = "??"
suffix = f" ({item.stat().st_size // 1024} KB)" if item.stat().st_size > 0 else " (空文件)"
entry = f"{prefix}{connector}{icon} {item.name}{suffix}"
contents.append(entry)
# 遞歸處理子目錄
if item.is_dir() and not item.is_symlink():
extension = " " if is_last else "│ "
contents.append(_tree(item, prefix + extension, depth + 1))
return "\n".join(contents) if contents else f"{prefix}└── ?? 空目錄"
root = Path(directory)
if not root.exists():
return f"? 路徑不存在: {directory}"
return f"?? 目錄樹 {root} (深度限制: {max_depth})\n" + _tree(root)
通過上面代碼,我們能夠去找指定路徑下面的所有完整路徑目錄。通過前面三個(gè)模塊,我們可以回到我們代碼所在的根目錄,然后通過這個(gè)代碼,我們就可以找到根目錄下面所有的目錄結(jié)構(gòu)。
2.5 子模塊4:目標(biāo)路徑檢查
根據(jù)前面三個(gè)子模塊,我們已經(jīng)可以找到目標(biāo)路徑?,F(xiàn)在就是驗(yàn)證目標(biāo)路徑是否存在即可,因此需要對目標(biāo)路徑進(jìn)行檢查。
def path_exists(path_str: str) -> bool:
"""通用路徑存在性檢查"""
return Path(path_str).exists()
3. 完整模塊展示
"""
path_analyzer.py - 多功能路徑分析工具
功能包含:
1. 腳本自身路徑信息展示
2. 智能目錄樹生成
3. 路徑存在性驗(yàn)證
4. 遞歸深度控制
"""
from pathlib import Path
import argparse
# 獲取腳本路徑信息
script_path = Path(__file__).resolve()
script_dir = script_path.parent
def show_script_info():
"""顯示腳本自身路徑信息"""
print(f"?? 腳本路徑: {script_path}")
print(f"?? 腳本目錄: {script_dir}\n")
def generate_file_tree(directory: str, max_depth: int = 3) -> str:
"""生成帶格式的目錄樹(優(yōu)化遞歸性能)"""
def _tree(path: Path, prefix: str = "", depth=0) -> str:
if depth > max_depth:
return ""
try:
items = sorted(path.iterdir(), key=lambda x: (not x.is_dir(), x.name.lower()))
except PermissionError:
return f"{prefix}└── ?? 權(quán)限不足"
except FileNotFoundError:
return f"{prefix}└── ? 目錄已消失"
contents = []
for index, item in enumerate(items):
is_last = index == len(items) - 1
connector = "└── " if is_last else "├── "
# 文件類型識別
if item.is_symlink():
icon = "??"
suffix = f" -> {item.resolve()}"
elif item.is_dir():
icon = "??"
suffix = ""
else:
icon = "??"
suffix = f" ({item.stat().st_size // 1024} KB)" if item.stat().st_size > 0 else " (空文件)"
entry = f"{prefix}{connector}{icon} {item.name}{suffix}"
contents.append(entry)
# 遞歸處理子目錄
if item.is_dir() and not item.is_symlink():
extension = " " if is_last else "│ "
contents.append(_tree(item, prefix + extension, depth + 1))
return "\n".join(contents) if contents else f"{prefix}└── ?? 空目錄"
root = Path(directory)
if not root.exists():
return f"? 路徑不存在: {directory}"
return f"?? 目錄樹 {root} (深度限制: {max_depth})\n" + _tree(root)
def path_check(path_str: str) -> dict:
"""增強(qiáng)型路徑檢查"""
path = Path(path_str)
status = {
'exists': path.exists(),
'is_file': path.is_file(),
'is_dir': path.is_dir(),
'size': path.stat().st_size if path.exists() else 0
}
return status
def main():
"""命令行入口點(diǎn)"""
parser = argparse.ArgumentParser(description="路徑分析工具")
parser.add_argument('path', nargs='?', default=str(script_dir), help="要分析的路徑(默認(rèn)為腳本目錄)")
parser.add_argument('-d', '--max-depth', type=int, default=3, help="目錄樹遞歸深度(默認(rèn)3)")
parser.add_argument('-q', '--quiet', action='store_true', help="靜默模式(不顯示腳本信息)")
args = parser.parse_args()
if not args.quiet:
show_script_info()
# 路徑有效性檢查
check_result = path_check(args.path)
if not check_result['exists']:
print(f"? 錯(cuò)誤:路徑不存在 - {args.path}")
return
# 生成目錄樹
tree = generate_file_tree(args.path, args.max_depth)
print(tree)
# 顯示統(tǒng)計(jì)信息
print(f"\n?? 路徑統(tǒng)計(jì):")
print(f" - 類型: {'目錄' if check_result['is_dir'] else '文件'}")
if check_result['is_dir']:
print(f" - 包含項(xiàng)目: {len(list(Path(args.path).iterdir()))}")
else:
print(f" - 文件大小: {check_result['size'] // 1024} KB")
if __name__ == "__main__":
main()
注意哈,上面的模塊代碼可以直接使用,僅僅需要修改的只有def main中的內(nèi)容,主要還是對文件路徑完整模塊的一些功能進(jìn)行調(diào)整(都已經(jīng)注釋好了)
到此這篇關(guān)于Python進(jìn)行文件路徑檢查的模塊詳解的文章就介紹到這了,更多相關(guān)Python文件路徑檢查內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于Python 內(nèi)置庫 itertools
今天得這篇文章就來給大家介紹一下Python的系統(tǒng)庫itertools的 相關(guān)資料,需要的小伙伴可以參考下面文章的具體內(nèi)容2021-09-09
python自動打開瀏覽器下載zip并提取內(nèi)容寫入excel
這篇文章主要給大家介紹了關(guān)于python自動打開瀏覽器下載zip并提取內(nèi)容寫入excel的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
Python串口通信的接收與發(fā)送的實(shí)現(xiàn)
串口通信是指通過串口進(jìn)行數(shù)據(jù)傳輸?shù)囊环N通信方式,本文就來介紹一下Python串口通信的接收與發(fā)送的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-11-11
Django在admin后臺集成TinyMCE富文本編輯器的例子
今天小編就為大家分享一篇Django在admin后臺集成TinyMCE富文本編輯器的例子,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-08-08
關(guān)于sklearn包導(dǎo)入錯(cuò)誤:ImportError:?cannot?import?name Type解
這篇文章主要介紹了關(guān)于sklearn包導(dǎo)入錯(cuò)誤:ImportError:?cannot?import?name‘Type‘解決方案,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02
Python?Scala中使用def語句定義方法的詳細(xì)過程
這篇文章主要介紹了Python?Scala中使用def語句定義方法,Scala的方法是類的一部分,而函數(shù)是一個(gè)對象可以賦值給一個(gè)變量,下面來講解Scala的方法,需要的朋友可以參考下2022-09-09

