本文目錄一覽:
- 1、Python其實很簡單 第十五章 文件操作
- 2、python怎麼獲取路徑下的所有文件夾名字?
- 3、python獲取文件夾下所有文件名
- 4、python–目錄操作
- 5、python 獲取文件夾下的所有文件名
- 6、列出文件夾下所有的文本文件名python
Python其實很簡單 第十五章 文件操作
在各種變量中保存的數據都是臨時的,隨着程序運行結束都會丟失。要做到數據長期有效,必須建立在磁盤中建立文件,將數據輸入到文件中並保存。需要獲取數據時需要打開文件讀取。
而我們自己建立的程序都是應用程序,從本質上講,應用程序是無法直接操作計算機的硬件的,譬如讀寫磁盤中文件,這就需要調用操作系統中的相應命令。接下來我們使用的Python內置函數open()、write()都是通過調用操作系統的相關命令才實現文件讀寫的,至於其中的細節,我們就不需要考慮了。
15.1創建和打開文件
在Python 中創建或打開文件,實際上是建立一個對象,該對象通過調用內置的open()函數創建或打開一個文件。
語法:
file object = open(filename [, mode][, buffering])
參數說明如下:
filename:file_name變量是一個包含了你要訪問的文件名稱的字符串值;
mode:mode決定了打開文件的模式:只讀,寫入,追加等。所有可取值見如下的完全列表。這個參數是非強制的,默認文件訪問模式為只讀(r)。
Buffering:如果buffering的值被設為0,就不會有寄存;如果buffering的值取1,訪問文件時會寄存行;如果將buffering的值設為大於1的整數,表明了這就是的寄存區的緩衝大小;如果取負值,寄存區的緩衝大小則為系統默認。
mode參數的參數值及說明
對於其中最難區別的r、r+、w、w+、a、a+幾個參數的區別總結如下,要特別注意指針的位置:
下面舉例說明open( )函數的使用方法。
例1:
file=open(‘1.py’)
如果文件“1.py”存在,則可以打開此文件;如果文件“1.py”不存在,則會出現如下提示:
Traceback (most recent call last):
File ” “, line 1, in
file=open(‘1.py’)
FileNotFoundError: [Errno 2] No such file or directory: ‘1.py’
例2:
file=open(‘4.py’,’a+’)
雖然文件“4.py”不存在,但運行並未出現錯誤,參見上表,“a+”的含義是以讀寫模式打開文件,如果該文件已經存在,新內容將以追加方式寫入;如果該文件不存在,則新建文件用於寫入。查看文件夾,發現已經生成了一個新的文件4.py。
例3:
file=open(‘python.png’,’rb’)
print(file)
運行結果:
這就是說,雖然Python可以打開一個圖片格式的文件,但print()並不能將其輸出,還需要第三方庫中模塊的相應方法去處理,如PIL中的open()f方法。
例4:
file = open(“f.txt”, “w”,encoding=’utf-8′)
# 以只寫模式打開文件f.txt,編碼方式為utf-8
print( “文件名: “, file.name) # 輸出文件名
print( “是否已關閉 : “, file.closed) # 文件是否打開
print( “訪問模式 : “, file.mode) # 文件訪問模式
運行結果:
文件名: f.txt
是否已關閉 : False
訪問模式 : w
例5:
15.2關閉文件
打開文件使用後要及時關閉,以免造成不必要的破壞,同時也可以釋放內存。在Python中使用close()方法可以關閉文件。
語法格式:
file.close()
其中,file為文件對象。
15.3 with語句
with 語句適用於對資源進行訪問的場合,確保不管使用過程中是否發生異常都會執行必要的“清理”操作,釋放資源,比如文件使用後自動關閉、線程中鎖的自動獲取和釋放等。
with語句的語法格式如下:
with expression as target:
with-body
其中,expression用於指定一個表達式,譬如打開文件的open()函數。target用於指定一個變量,並且將expression的結果保存到該變量中,譬如文件對象file。with-body用於指定with語句體,譬如一些文件操作的相關語句,如果沒有要執行的語句體,則直接用pass語句代替。
假設python當前目錄下存在一個test.txt文件,其內容如下:
Python是一種解釋型語言: 這意味着開發過程中沒有了編譯這個環節。類似於PHP和Perl語言。
Python是交互式語言: 這意味着,您可以在一個 Python 提示符 後直接執行代碼。
Python是面向對象語言: 這意味着Python支持面向對象的風格或代碼封裝在對象的編程技術。
Python是初學者的語言:Python 對初級程序員而言,是一種偉大的語言,它支持廣泛的應用程序開發。
舉例如下:
with open(‘test.txt’,’r’,encoding=’utf-8′) as file:
line=file.readline() # readline()方法可以讀取文件一行數據,接下來就會講到。
print(line)
運行結果如下:
Python是一種解釋型語言: 這意味着開發過程中沒有了編譯這個環節。類似於PHP和Perl語言。
而此時,我們給該段代碼with語句之外再增加一個讀取文件的語句,代碼如下:
with open(‘test.txt’,’r’,encoding=’utf-8′) as file:
line=file.readline()
print(line)
line2=file.readline()
print(line2)
發現出現了如下錯誤提示:
Traceback (most recent call last):
File “C:/Users/zym/AppData/Local/Programs/Python/Python39/3.py”, line 5, in
line2=file.readline()
ValueError: I/O operation on closed file.
意思是要讀取的文件已經被關閉了。
由此可知,當with語句運行結束後,被打開的test.txt文件就自動關閉了。
15.4讀取文件
在Python 中讀取文件的方法有:
1、讀取指定個數的字符
格式如下:
File.read([size])
其中,file為打開的文件對象。size為可選參數,可以指定要讀取的字符個數,省缺表示讀取所有內容。
在調用read()方法讀取文件內容時,文件必須是以r(只讀)或者r+(讀寫)方式打開。
如:
with open(‘test.txt’,’r’,encoding=’utf-8′) as file:
txt=file.read() (或txt=file.read(10))
print(txt)
將讀取、輸出test.txt文件的全部內容(或前10個字符)。
2、移動文件的指針
對於剛打開的文件,文件指針總是指向文件頭的。也可以通過seek()方法將文件的指針移動到新的位置。
格式如下:
file.seek(offset[,whence])
其中,file表示已經打開的文件對象;offset用於指定移動的字符個數;whence表示從哪個位置起始計算個數,其值為0表示從文件頭開始計算,其值為1表示從當前位置開始計算,其值為2表示從文件尾開始計算,默認值為0。
例如:
with open(‘test.txt’,’r’,encoding=’utf-8′) as file:
string=file.read(9)
print(‘取9個字符: ‘+string)
file.seek(2) #指針從文件頭開始移動2個字符
string=file.read(9) #從當前位置讀取10個字符
輸出結果:
取9個字符:
Python是一種
取9個字符:
thon是一種解釋
而下面的代碼會拋出錯誤:
with open(‘test.txt’,’r’,encoding=’utf-8′) as file:
file.seek(2,1) #指針從當前位置開始移動2個字符
string=file.read(10) #從當前位置讀取10個字符
print(‘取10個字符: ‘+string)
錯誤提示為:
Traceback (most recent call last):
File “C:UserszymAppDataLocalProgramsPythonPython393.py”, line 7, in
file.seek(2,1) #指針從當前位置開始移動2個字符
io.UnsupportedOperation: can’t do nonzero cur-relative seeks
原因在於,必須使用b模式(即rb)打開文件,才能使用whence參數。但是,b模式(二進制)不適合文本文件。對於test.txt這樣的文本文件,為了解決通過改變指針讀取任意位置字符,可以採用加一個位置變量的方法來存儲指針的值。
例如:
with open(‘test.txt’,’r’,encoding=’utf-8′) as file:
#utf-8漢字與英文字符都佔一個字符
string=” #設置一個空字符串
pointer=0 #當前指針為0
str1=file.read(6) #讀取6個字符
pointer+=6 #指針變量後移6個字符
string+=str1 #string用來存放已讀取的字符
print(‘取6個字符: ‘,str1)
file.seek(pointer) #指針從文件頭開始移動2個字符
str1=file.read(8) #從當前位置讀取10個字符
pointer+=8 #指針跳過已讀取的字符
string+=str1
print(‘再取8個字符: ‘,str1)
print(‘所有讀取的字符: ‘,string)
print(‘當前指針所處的位置: ‘,pointer)
str1=file.read(1)
print(‘當前指針所處的字符: ‘,str1)
運行結果如下:
取6個字符:
Python
再取8個字符:
是一種解釋型語言
所有讀取的字符:
Python是一種解釋型語言
當前指針所處的位置:
14
當前指針所處的字符:
:
3、讀取一行數據readline()方法
語法格式:
file.readline()
例:
with open(‘test.txt’,’r’,encoding=’utf-8′) as f:
string=f.read(1) # 讀取文件的第一個字符
if string != ”: # 防止文件為空文件
lineno=0
while True:
line=f.readline()
if line != ”:
lineno+=1
print(‘第’+str(lineno)+’行:’+line,end=”)
# 因為每行都有自帶的分行符,print()語句不允許換行
else:
break # 出現空行時停止讀取
else:
print(‘要讀取的文件為空文件!’)
運行結果:
第1行:ython是一種解釋型語言: 這意味着開發過程中沒有了編譯這個環節。類似於PHP和Perl語言。
第2行:Python是交互式語言: 這意味着,您可以在一個 Python 提示符 後直接執行代碼。
第3行:Python是面向對象語言: 這意味着Python支持面向對象的風格或代碼封裝在對象的編程技術。
第4行:Python是初學者的語言:Python 對初級程序員而言,是一種偉大的語言,它支持廣泛的應用程序開發。
4、讀取全部行命令readlines()方法
語法格式:
File.readlines()
該方法與read()方法一樣,在調用read()方法讀取文件內容時,文件必須是以r(只讀)或者r+(讀寫)方式打開。
例:
with open(‘test.txt’,’r’,encoding=’utf-8′) as f:
txt=f.readlines()
print(txt)
運行結果:
[‘Python是一種解釋型語言: 這意味着開發過程中沒有了編譯這個環節。類似於PHP和Perl語言。 ‘, ‘Python是交互式語言: 這意味着,您可以在一個 Python 提示符 後直接執行代碼。 ‘, ‘Python是面向對象語言: 這意味着Python支持面向對象的風格或代碼封裝在對象的編程技術。 ‘, ‘Python是初學者的語言:Python 對初級程序員而言,是一種偉大的語言,它支持廣泛的應用程序開發。 ‘]
從上面的運行結果可以看出,readlines()方法的返回值為一個字符串列表。所以,也可以以讀取列表元素的方法輸出。如下所示:
with open(‘test.txt’,’r’,encoding=’utf-8′) as f:
txt=f.readlines()
for line in txt:
print(line,end=”)
運行結果:
Python是一種解釋型語言: 這意味着開發過程中沒有了編譯這個環節。類似於PHP和Perl語言。
Python是交互式語言: 這意味着,您可以在一個 Python 提示符 後直接執行代碼。
Python是面向對象語言: 這意味着Python支持面向對象的風格或代碼封裝在對象的編程技術。
Python是初學者的語言:Python 對初級程序員而言,是一種偉大的語言,它支持廣泛的應用程序開發。
15.5 寫入文件內容
語法格式如下:
file.write(string)
其中,file為打開的文件對象,string為要寫入的字符串。
寫入文件內容時,文件必須以w(可寫)或a(追加)模式打開。否則,會拋出如下異常提示:
Traceback (most recent call last):
File “C:UsersAdministratorAppDataLocalProgramsPythonPython383.py”, line 2, in
f.write(‘人生苦短,我用Python!’)
io.UnsupportedOperation: not writable
關於write()方法的用法舉例如下:
with open(‘test.txt’,’a’,encoding=’utf-8′) as f:
f.write(‘人生苦短,我用Python!’)
with open(‘test.txt’,’r’,encoding=’utf-8′) as f:
txt=f.read()
print(txt)
運行結果:
Python是一種解釋型語言: 這意味着開發過程中沒有了編譯這個環節。類似於PHP和Perl語言。
Python是交互式語言: 這意味着,您可以在一個 Python 提示符 後直接執行代碼。
Python是面向對象語言: 這意味着Python支持面向對象的風格或代碼封裝在對象的編程技術。
Python是初學者的語言:Python 對初級程序員而言,是一種偉大的語言,它支持廣泛的應用程序開發。
人生苦短,我用Python!
可以看出,由於文件的打開方式為a模式(追加模式),寫入的內容被寫入到文件的末尾。
在Python中,文件操作方法里沒有類似於字符串內的計算長度、查找、替換、截取、分隔等方法,為什麼沒有?原因可能是文件的類型太複雜,譬如說二進制文件,上述操作的意義不大。如果僅僅要對文本文件進行上述操作,完全可以先把文件的內容讀取到字符串中,再用相應的字符串函數或方法去操作就可以了。譬如,要將test.txt文件中的字符串‘Python’替換為’PHP’,則可以用如下代碼完成:
txt1=”
with open(‘test.txt’,’r’,encoding=’utf-8′) as f:
txt1=f.read() #先將文件內容存入字符串txt1中
txt2=txt1.replace(‘Python’,’PHP’) #將txt1中的’Python’替換為’PHP’,並存入txt2
with open(‘test.txt’,’w’,encoding=’utf-8′) as f:
f.write(txt2) #將字符串txt2的內容寫回到文件中
這裡之所以分兩步打開文件(第一次為r模式,第二次為w模式),而沒有採用一次讀寫(r+、w+方式),因為那樣比較容易出錯。實踐證明,將文件的讀操作和寫操作分開其實是非常正確的選擇。
python怎麼獲取路徑下的所有文件夾名字?
import os
os.chdir(“D:\\python”) #設置需要查看的目錄
a = [x for x in os.listdir() if os.path.isdir(x)]
列表a裡面就是當前目錄下的文件夾名字
python獲取文件夾下所有文件名
使用os模塊可以獲取指定文件夾下所有文件名,有兩個方法os.walk()和os.listdir().
(1)os.walk可以用於遍歷指定文件下所有的子目錄、非目錄子文件。
(2)os.listdir()用於返回指定的文件夾下包含的文件或文件夾名字的列表,這個列表按字母順序排序。
python–目錄操作
一、os.getcwd()
獲取當前工作目錄,即當前Python腳本工作的目錄路徑。
二、os. chdir(path)
改變當前腳本工作目錄;相當於shell下的cd命令。
三、os.pardir
返回當前目錄的父目錄(’..’)
四、獲取當前使用的操作系統類型(其中 ‘nt’ 是 windows,’posix’ 是linux 或者 unix)。
五、os.mkdir(path [, mode=0777])
生成單級目錄;相當於linux中的mkdir dirname。參數mode表示生成的目錄的權限,默認是超級權限,也就是0777。如果重複創建,會報錯
六、os.makedirs(path [, mode=0777])
可生成多層遞歸目錄,父目錄如果不存在,遞歸生成。參數mode表示生成的目錄的權限,默認是超級權限,也就是0777。
七、os.removedirs(path)
若目錄為空,則刪除,並遞歸到上一級目錄,如若也為空,則刪除,依次類推。
八、os.rmdir(path)
刪除單級空目錄,若目錄不為空則無法刪除,會報錯;相當Linux中的rmdir dirname。
九、os.listdir(path)
列出指定目錄下的所有文件和子目錄,包括隱藏文件或目錄,並以列表形式返回。
十、os.remove(filePath)
刪除一個指定的文件,參數filePath表示文件所在的路徑。
注意:該方法只能刪除文件,不能刪除目錄。
十一、os.rename(oldname, newname)
重命名文件/目錄。
十二、os.access(path, mode)
輸出文件權限模式。
十三、os.chmod(path, mode)
修改文件的權限。
十四、os.walk(top, topdown=True, onerror=None, followlinks=False)
➢top:表示需要遍歷的目錄樹的路徑。
➢topdown的默認值是“True”,表示首先返回目錄樹下的文件,然後遍歷目錄樹下的子目錄。值設為False時,則表示先遍歷目錄樹下的子目錄,返回子目錄下的文件,最後返回根目錄下的文件。
➢onerror的默認值是“None”,表示忽略文件遍歷時產生的錯誤。如果不為空,則提供一個自定義函數提示錯誤信息後繼續遍歷或拋出異常中止遍歷。
➢該函數返回一個列表,列表中的每一個元素都是一個元組,該元組有3個元素,分別表示每次遍歷的路徑名,目錄列表和文件列表。
➢默認情況下,os.walk 不會遍歷軟鏈接指向的子目錄,若有需要請將followlinks設定為true
十五、os.path.split(path)
將path分割成目錄和文件名(事實上,如果你完全使用目錄,它也會將最後一個目錄作為文件名而分離,同時它不會判斷文件或目錄是否存在),並存於元組中返回。
十六、os.path.exists(path)
判斷path是否存在,如果存在返回True,否則返回False。
十七、os.path.isfile(path)
判斷path是否是文件,如果是返回True,否則返回False。
十八、os.path.isdir(path)
判斷path是否是目錄,如果是目錄返回True,否則返回False。
十九、os.path.getsize(name)
獲得文件大小,如果name是目錄返回結果是0L或者4096L;如果name代表的目錄或文件不存在,則會報WindowsError異常。
二十、os.path.join(a, *p)
連接兩個或更多的路徑名,中間以“\”分隔,如果所給的參數中都是絕對路徑名,那先給的絕對路徑將會被丟棄。
二十一、os.path.getatime(filename)
返迴文件的最後訪問時間,返回的是時間戳。
二十二、os.path.getctime(filename)
以時間戳的形式返迴文件或目錄的創建時間,在Unix系統上是文件最近更改的時間,在Windows上是文件或目錄的創建時間。
1.基礎題:
檢驗給出的路徑是否是一個文件:os.path.isfile(“D:\\test.txt”)
檢驗給出的路徑是否是一個目錄:os.path.isdir(“D:\\test.txt”)
判斷是否是絕對路徑:os.path.isabs(“D:\\test.txt”)
檢驗給出的路徑是否真地存在:
2.返回一個路徑的目錄名和文件名 :os.listdir(“D:\\”)
3.分離文件名與擴展名 :os.path.splitext(“D:\\test.txt”)
4.找出某個目錄下所有的文件,並在每個文件中寫入“gloryroad” :
for files in os.walk(“D:\\test”):
… print(files)
…
(‘D:\\test’, [], [‘a.txt’, ‘b.txt’, ‘test.txt’, ‘test1.txt’])
with open(“D:\\test\\a.txt”,”w+”) as f:
… f.write(“gloryroad”)
5.如果某個目錄下文件名包含txt後綴名,則把文件後面追加寫一行“被我找到了!”
6. 命題練習:
1) 一個目錄下只有文件(自己構造),拷貝幾個文件(手工完成)
2 )用listdir函數獲取所有文件,如果文件的創建時間是今天,那麼就在文件裡面寫上文件的路徑、文件名和文件擴展名
3) 如果不是今天創建(獲取文件的創建時間,並轉化為時間格式,判斷是否今天),請刪除
4 )計算一下這個程序的執行耗時
7.刪除某個目錄下的全部文件
8.統計某個目錄下文件數和目錄個數
9.使用程序建立一個多級的目錄,在每個目錄下,新建一個和目錄名字一樣的txt文件
10. 查找某個目錄下是否存在某個文件名
11. 用系統命令拷貝文件
12.輸入源文件所在路徑和目標目錄路徑,然後實現文件拷貝功能
13.遍歷某個目錄下的所有圖片,並在圖片名稱後面增加
14、遍歷指定目錄下的所有文件,找出其中佔用空間最大的前3個文件
15、過濾py源碼中的#注釋,另存為文件result.py,並執行result.py,斷言是否執行成功
16、文件訪問,提示輸入數字 N 和文件 F, 然後顯示文件 F 的前 N 行.
17、從命令行接受1個路徑如:c:\a\b\c\1.py, 實現1個函數創建目錄a\b\c,創建文件1.py,實現1個函數刪除已創建的目錄及文件
18、有一個ip.txt,裡面每行是一個ip,實現一個函數,ping 每個ip的結果,把結果記錄存到ping.txt中,格式為ip:0或ip:1 ,0代表ping成功,1代表ping失敗
19、實現DOS命令執行功能,接受輸入命令並執行,然後把執行結果和返回碼打印到屏幕
20、文件訪問
訪問一存在多行的文件,實現每隔一秒逐行顯示文本內容的程序,每次顯示文本文件的 5行, 暫停並向用戶提示“輸入任意字符繼續”,按回車鍵後繼續執行,直到文件末尾。
顯示文件的格式為:[當前時間] 一行內容,比如:[2016-07-08 22:21:51] 999370this is test
python 獲取文件夾下的所有文件名
獲取文件夾下所有名稱的方法:
把軟件程序運行之後,選擇添加文件名稱管理。
在裡面將所有的數據信息進行選定,然後點擊獲取。
列出文件夾下所有的文本文件名python
src_dir = r’./’ # 源文件目錄地址
def list_all_files(rootdir):
import os
_files = []
#列出文件夾下所有的目錄與文件
list_file = os.listdir(rootdir)
for i in range(0,len(list_file)):
# 構造路徑
path = os.path.join(rootdir,list_file[i])
# 判斷路徑是否是一個文件目錄或者文件
# 如果是文件目錄,繼續遞歸
if os.path.isdir(path):
_files.extend(list_all_files(path))
if os.path.isfile(path):
_files.append(path)
return _files
files = list_all_files(src_dir)
print(files)
原創文章,作者:YUC66,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/128599.html