Python中文件的讀取和寫入操作
從文件中讀取數(shù)據(jù)
讀取整個(gè)文件
這里假設(shè)在當(dāng)前目錄下有一個(gè)文件名為'pi_digits.txt'的文本文件,里面的數(shù)據(jù)如下:
3.1415926535
8979323846
2643383279
with open('pi_digits.txt') as f: # 默認(rèn)模式為‘r',只讀模式 contents = f.read() # 讀取文件全部?jī)?nèi)容 print contents # 輸出時(shí)在最后會(huì)多出一行(read()函數(shù)到達(dá)文件末會(huì)返回一個(gè)空字符,顯示出空字符就是一個(gè)空行) print '------------' print contents.rstrip() # rstrip()函數(shù)用于刪除字符串末的空白
3.1415926535
8979323846
2643383279
------------
3.1415926535
8979323846
2643383279
逐行讀取
可以通過循環(huán)來(lái)實(shí)現(xiàn)逐行讀取數(shù)據(jù):
with open('pi_digits.txt') as f: for line1 in f: print line1 # 每行末尾會(huì)有一個(gè)換行符 print '------------' for line2 in f: print line2.rstrip() # 此時(shí)文件已經(jīng)讀完,line2指向文本末尾,因此不會(huì)有輸出
3.1415926535
8979323846
2643383279
------------
讀取文件時(shí)相當(dāng)于有一個(gè)指針在記錄讀取的位置,數(shù)據(jù)讀到哪,這個(gè)指針就指到哪邊,繼續(xù)讀取數(shù)據(jù)時(shí)會(huì)從該位置繼續(xù)讀取,因此上面代碼中第二個(gè)循環(huán)中輸出為空。將上述代碼稍加修改如下:
with open('pi_digits.txt') as f: for line1 in f: print line1 print '------------' with open('pi_digits.txt') as f: # 需要重新打開文本進(jìn)行讀取 for line2 in f: print line2.rstrip() # 刪除字符串末尾的空白
3.1415926535
8979323846
2643383279
------------
3.1415926535
8979323846
2643383279
上述代碼相當(dāng)于第一次讀取完后關(guān)閉該文件又重新打開進(jìn)行讀取。逐行讀取數(shù)據(jù)也可以用readline()函數(shù),如下:
with open('pi_digits.txt') as f: # readline()每一次讀取一行數(shù)據(jù),并指向該行末尾 line1 = f.readline() # 讀取第一行數(shù)據(jù)(此時(shí)已經(jīng)指向第一行末尾) line2 = f.readline() # 從上一次讀取末尾開始讀取(第二行) print line1.rstrip() print line2.rstrip()
3.1415926535
8979323846
有時(shí)候我們想要一次性讀取全部數(shù)據(jù)并且按分開存儲(chǔ)以便于后續(xù)的操作,當(dāng)然用上面的循環(huán)可以實(shí)現(xiàn),但python提供了更簡(jiǎn)單的方法readlines():
with open('pi_digits.txt') as f: lines = f.readlines() # 讀取文本中所有內(nèi)容,并保存在一個(gè)列表中,列表中每一個(gè)元素對(duì)應(yīng)一行數(shù)據(jù) print lines # 每一行數(shù)據(jù)都包含了換行符 print '------------' for line in lines: print line.rstrip() print '------------' pi_str = '' # 初始化為空字符 for line in lines: pi_str += line.rstrip() #字符串連接 print pi_str
['3.1415926535\n', '8979323846\n', '2643383279\n']
------------
3.1415926535
8979323846
2643383279
------------
3.141592653589793238462643383279
寫數(shù)據(jù)到文件
寫數(shù)據(jù)有幾種不同的模式,最常用的是w', ‘a(chǎn)', 分別表示擦除原有數(shù)據(jù)再寫入和將數(shù)據(jù)寫到原數(shù)據(jù)之后:
filename = 'write_data.txt' with open(filename,'w') as f: # 如果filename不存在會(huì)自動(dòng)創(chuàng)建, 'w'表示寫數(shù)據(jù),寫之前會(huì)清空文件中的原有數(shù)據(jù)! f.write("I am Meringue.\n") f.write("I am now studying in NJTECH.\n")
此時(shí)會(huì)在當(dāng)前路徑下創(chuàng)建一個(gè)'write_data.txt'的文本文件,并向文件中寫入數(shù)據(jù)如下:
I am Meringue.
I am now studying in NJTECH.
下面繼續(xù)在該文件中加入新數(shù)據(jù):
with open(filename,'a') as f: # 'a'表示append,即在原來(lái)文件內(nèi)容后繼續(xù)寫數(shù)據(jù)(不清楚原有數(shù)據(jù)) f.write("I major in Machine learning and Computer vision.\n")
此時(shí)的文件內(nèi)容為:
I am Meringue.
I am now studying in NJTECH.
I major in Machine learning and Computer vision.
總結(jié)
以上所述是小編給大家介紹的Python中文件的讀取和寫入操作,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
基于Python實(shí)現(xiàn)口罩佩戴檢測(cè)功能
這篇文章主要介紹了基于Python實(shí)現(xiàn)的口罩佩戴檢測(cè),在本次實(shí)驗(yàn)中,我們要建立一個(gè)目標(biāo)檢測(cè)的模型,可以識(shí)別圖中的人是否佩戴了口罩,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2022-05-05python數(shù)據(jù)封裝json格式數(shù)據(jù)
本次內(nèi)容是小編在網(wǎng)上整理的關(guān)于如何python數(shù)據(jù)封裝json格式的內(nèi)容總結(jié),有興趣的讀者們參考下。2018-03-03python實(shí)現(xiàn)的登陸Discuz!論壇通用代碼分享
這篇文章主要介紹了python實(shí)現(xiàn)的登陸Discuz!論壇通用代碼分享,需要的朋友可以參考下2014-07-07