Python文件及目錄處理的方法
下面先來介紹python目錄處理相關(guān)方法。
一、目錄操作
1. 獲取當(dāng)前代碼路徑
test_folder.py import os import sys print(__file__) print(sys.argv[0]) print(os.path.realpath(__file__)) print(os.path.abspath(sys.argv[0]))
Out:
D:/ProgramWorkspace/PythonNotes/03-File-Handling/test_folder.py
D:/ProgramWorkspace/PythonNotes/03-File-Handling/test_folder.py
D:\ProgramWorkspace\PythonNotes\03-File-Handling\test_folder.py
D:\ProgramWorkspace\PythonNotes\03-File-Handling\test_folder.py
2. 獲取當(dāng)前文件__file__的所在目錄
print(os.getcwd()) print(os.path.dirname(os.path.realpath(__file__))) print(os.path.split(os.path.realpath(__file__))[0]) path = os.path.dirname(os.path.realpath(__file__))
Out:
D:\ProgramWorkspace\PythonNotes\03-File-Handling
D:\ProgramWorkspace\PythonNotes\03-File-Handling
D:\ProgramWorkspace\PythonNotes\03-File-Handling
3. 獲取當(dāng)前文件名名稱
print(os.path.basename(sys.argv[0])) # 當(dāng)前文件名名稱 print(os.path.basename(__file__))
Out:
test_folder.py
test_folder.py
4. 拼接路徑
path = os.path.dirname(os.path.realpath(__file__)) filename = os.path.basename(__file__) abspath = os.path.join(path, filename) print(abspath)
Out:
D:\ProgramWorkspace\PythonNotes\03-File-Handling\test_folder.py
5. 創(chuàng)建目錄
判斷目錄是否存在:
os.path.exists(path)
創(chuàng)建目錄:
if not os.path.exists(path):
print(f"創(chuàng)建文件夾: {path}")
os.makedirs(path)
二、文件操作
1. 創(chuàng)建文本文件
text = "Hello World!" newfilepath = os.path.join(path, "newfile.txt") file = open(newfilepath, 'w') file.write(text) # 寫入內(nèi)容信息 file.close()
2. 判斷文件是否存在
print(os.path.isfile(path)) print(os.path.isfile(newfilepath)) print(os.path.exists(newfilepath))
Out:
False
True
True
os.path.isfile 用于判斷是否為文件且是否存在,os.path.exists 也可以用于判斷文件是否存在,但還是建議使用os.path.isfile 判斷文件,os.path.exists 判斷目錄是否存在。比如,某個(gè)文件為newfile,使用這兩個(gè)方法都會(huì)返回True,無法判斷到底是文件還是目錄。
3. 判斷文件屬性
print(os.access(newfilepath,os.F_OK)) # 文件是否存在 print(os.access(newfilepath,os.R_OK)) # 文件是否可讀 print(os.access(newfilepath,os.W_OK)) # 文件是否可以寫入 print(os.access(newfilepath,os.X_OK)) # 文件是否有執(zhí)行權(quán)限
Out:
True
True
True
True
os.access(newfilepath,os.F_OK) 也可以用于判斷文件是否存在。
4. 打開文件
打開文本文件或者二進(jìn)制文件可以使用 open() 方法:
f = open(filename, mode)
幾種文件打開模式:
b:二進(jìn)制模式t:文本模式(默認(rèn))r: 打開存在的文件,讀操作(默認(rèn))。w: 打開文件,寫操作,先前文件中的內(nèi)容會(huì)被刪除。如果文件不存在會(huì)自動(dòng)創(chuàng)建。a: 打開文件,追加操作,不會(huì)刪除先前文件中的內(nèi)容。如果文件不存在會(huì)自動(dòng)創(chuàng)建。x:創(chuàng)建新文件,寫操作,使用此模式打開存在的文件會(huì)拋出異常。r+: 讀、寫操作,不會(huì)刪除先前文件中的內(nèi)容,但是會(huì)覆蓋內(nèi)容。w+: ?寫、讀操作,會(huì)刪除先前文件中的內(nèi)容。a+: 追加、讀操作,不會(huì)刪除和覆蓋先前文件中的內(nèi)容。x+:創(chuàng)建新文件,讀寫操作。
open()方法的默認(rèn)模式為 rt 模式,也就是讀文本文件。
另外需要注意filename的寫法,比如文件路徑是:D:\test.txt ,其中\(zhòng)t 可能會(huì)被轉(zhuǎn)義,需要自前面加一個(gè) r :
f = open(r"D:\test.txt", "w")
5. 寫文件
讀寫文件都需要先打開文件,返回一個(gè)文件對(duì)象,然后對(duì)文件對(duì)象進(jìn)行讀寫操作。寫文件需要設(shè)置寫權(quán)限,比如 w、w+、a 模式。
寫文件主要包括兩種方法:
file.write(str):寫入字符串file.writelines(list):寫入字符串列表,用于同時(shí)插入多個(gè)字符串。
舉個(gè)栗子:
file = open("newfile.txt", 'w')
text1 = "Hello World!\n你好,世界!\r"
file.write(text1) # 寫入內(nèi)容信息
text2 = ["To the time to life, \n", "rather than to life in time.\r"]
file.writelines(text2)
file.close()
w 模式會(huì)刪除先前文件中的內(nèi)容,如果不想刪除,需要直接追加到后面,可以使用a 和 a+ 模式:
file = open("newfile.txt", 'a')
6. 讀文件
常見的讀取文件方法有以下幾種:
in操作符read():讀取所有數(shù)據(jù),返回一個(gè)字符串。readline():讀取第一行readlines():讀取所有行,每行保存為列表的一個(gè)元素。
# 打開并讀取文件
file = open("newfile.txt", 'r')
for line in file:
print(line)
print()
file.seek(0, 0)
print(file.read(5)) #
print()
file.seek(0, 0)
print(file.readline(12))
print()
file.seek(0, 0)
print(file.readlines())
print()
file.close()
執(zhí)行結(jié)果:
Hello World! 你好,世界! To the time to life, rather than to life in time. Hello Hello World! ['Hello World!\n', '你好,世界!\n', 'To the time to life, \n', 'rather than to life in time.\n']
讀取file對(duì)象的所有內(nèi)容后,文本的光標(biāo)會(huì)移動(dòng)到最后,再次讀取file需要將光標(biāo)移到前面,使用 file.seek(0, 0) 方法可以將光標(biāo)移到前面。還有一種解決方案是將讀取的內(nèi)容存一個(gè)在局部變量中。
7. with語句
with語句可用于異常處理,可以確保資源的適當(dāng)獲取及自動(dòng)釋放。使用with語句后就不需要調(diào)用file.close() 語句了,它會(huì)自動(dòng)釋放。
text1 = "Hello World!\n你好,世界!\r"
text2 = ["To the time to life, \n", "rather than to life in time.\r"]
# 寫
with open("newfile.txt", "w") as file:
file.write(text1)
file.writelines(text2)
# 讀
with open("newfile.txt", "r+") as file:
print(file.read())
with語句對(duì)處理大文件非常有用,比如10G大小的文件, with語句會(huì)進(jìn)行上下文管理。
到此這篇關(guān)于Python文件及目錄處理的方法的文章就介紹到這了,更多相關(guān)Python文件及目錄處理方法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python使用psutil模塊獲取系統(tǒng)狀態(tài)
作為程序猿,大家可能都熟悉linux系統(tǒng)的基礎(chǔ)信息獲取方法都是通過shell來獲取,但是在python中,我們還可以使用psutil模塊來獲取系統(tǒng)信息。psutil模塊把shell查看系統(tǒng)基礎(chǔ)信息的功能都包裝了下,使用更加簡(jiǎn)單,功能豐富。2016-08-08
Python DataFrame一列拆成多列以及一行拆成多行
這篇文章主要介紹了Python DataFrame一列拆成多列以及一行拆成多行,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
Python使用multiprocessing實(shí)現(xiàn)多進(jìn)程
當(dāng)我們工作中涉及到處理大量數(shù)據(jù)、并行計(jì)算或并發(fā)任務(wù)時(shí),Python的multiprocessing模塊是一個(gè)強(qiáng)大而實(shí)用的工具,在本文中,我們將探索如何使用multiprocessing模塊實(shí)現(xiàn)多進(jìn)程編程,將介紹進(jìn)程池的概念和用法,需要的朋友可以參考下2024-10-10
Anaconda+Pycharm+Pytorch虛擬環(huán)境創(chuàng)建(各種包安裝保姆級(jí)教學(xué))
相信很多時(shí)候大家都會(huì)用到虛擬環(huán)境,他具有可以讓你快速切換不同的python版本,本文主要介紹了Anaconda+Pycharm+Pytorch虛擬環(huán)境創(chuàng)建,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10
Python 實(shí)現(xiàn)日志同時(shí)輸出到屏幕和文件
這篇文章主要介紹了Python 實(shí)現(xiàn)日志同時(shí)輸出到屏幕和文件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-02-02
Python調(diào)用百度OCR實(shí)現(xiàn)圖片文字識(shí)別的示例代碼
這篇文章主要介紹了Python調(diào)用百度OCR實(shí)現(xiàn)圖片文字識(shí)別的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
解讀torch.cuda.amp自動(dòng)混合精度訓(xùn)練之節(jié)省顯存并加快推理速度
這篇文章主要介紹了torch.cuda.amp自動(dòng)混合精度訓(xùn)練之節(jié)省顯存并加快推理速度問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08

