1.os.mknod(「test.txt」) #建立空檔案
2.fp = open(「test.txt」,w) #直接開啟乙個檔案,如果檔案不存在則建立檔案
3.關於open 模式:
詳情:w:以寫方式開啟,
a:以追加模式開啟 (從 eof 開始, 必要時建立新檔案)
r+:以讀寫模式開啟
w+:以讀寫模式開啟 (參見 w )
a+:以讀寫模式開啟 (參見 a )
rb:以二進位制讀模式開啟
wb:以二進位制寫模式開啟 (參見 w )
ab:以二進位制追加模式開啟 (參見 a )
rb+:以二進位制讀寫模式開啟 (參見 r+ )
wb+:以二進位制讀寫模式開啟 (參見 w+ )
ab+:以二進位制讀寫模式開啟 (參見 a+ )
fp.read([size]) #size為讀取的長度,以byte為單位
fp.readlfemadlkoqine([size]) #讀一行,如果定義了size,有可能返回的只是一行的一部分
fp.readlines([size]) #把檔案每一行作為乙個list的乙個成員,並返回這個list。其實它的內部是通過迴圈呼叫readline()來實現的。如果提供size引數,size是表示讀取內容的總長,也就是說可能唯讀到檔案的一部分。
fp.write(str) #把str寫到檔案中,write()並不會在str後加上乙個換行符
fp.writelines(seq) #把seq的內容全部寫到檔案中(多行一次性寫入)。這個函式也只是忠實地寫入,不會在每行後面加上任何東西。
fp.close() #關閉檔案。python會在乙個檔案不用後自動關閉檔案,不過這一功能沒***,最好還是養成自己關閉的習慣。 如果乙個檔案在關閉後還對其進行操作會產生valueerror
fp.flush() #把緩衝區的內容寫入硬碟
fp.fileno() #返回乙個長整型的」檔案標籤「
fp.isatty() #檔案是否是乙個終端裝置檔案(unix系統中的)
fp.tell() #返回檔案操作標記的當前位置,以檔案的開頭為原點
fp.next() #返回下一行,並將檔案操作標記位移到下一行。把乙個file用於for … in file這樣的語句時,就是呼叫next()函式來實現遍歷的。
fp.seek(offset[,whence]) #將檔案打操作標記移到offset的位置。這個offset一般是相對於檔案的開頭來計算的,一般為正數。但如果提供了whence引數就不一定了,whence可以為0表示從頭開始計算,1表示以當前位置為原點計算。2表示以檔案末尾為原點進行計算。需要注意,如果檔案以a或a+的模式開啟,每次進行寫操作時,檔案操作標記會自動返回到檔案末尾。
fp.truncate([size]) #把檔案裁成規定的大小,預設的是裁到當前檔案操作標記的位置。如果size比檔案的大小還要大,依據系統的不同可能是不改變檔案,也可能是用0把檔案補到相應的大小,也可能是以一些隨機的內容加上去。
#coding: utf-8
#開啟檔案open(),預設唯讀"r".
#exp1:相對路徑
f = open(".\\test001.txt")
data = f.read()
print(data)
#exp2:絕對路徑
f = open("test001.txt","r")
data = f.read()
print(data)
#exp3:絕對路徑
f = open("d:\\mytest\\test001.txt")
data = f.read()
print(data)
#開啟並關閉檔案:
f = open("test001.txt","r")
data = f.read()
print(data)
f.close()
#寫檔案write()不換行:
f = open("test001.txt","w")
f.write("ddddddddddddd"+"\n")
f.close()
第一種方式讀寫指定行:
#寫檔案writelines()換行:
with open("test001.txt","w") as z:
z.write("33333333"+"\n")
z.write("cccccccccc"+"\n")
#讀取指定行:
with open("test001.txt",'r') aswww.cppcns.com x:
line = x.readlines()
first_line = line[0]
second_line = line[1]
print(first_line)
print(second_line)
第二種方式讀寫指定行:
#coding: utf-8
#將檔案讀進列表(反覆追加)中:
lines =
with open("test001.txt","r") as y:
for line in y:
lines.append(line)
y.close()
#在列表中插入文字資料:
lines.insert(0, "aaaa\n")
lines.insert(1, "bbbb\n")
print(lines)
#利用分隔符連線:
s = ''.join(lines)
print(s)
#寫到檔案中去:
with open("test001.txt","w") as z:
z.write(s)
z.close()
#再次讀取檔案中的資料:
with open("test001.txt","r") as x:
data = x.read()
print(data)
x.close()
#清空列表:
del lines[:]
print(lines)
第三種方式讀寫指定行:
#coding: utf-8
#在列表中插入文字資料:
lines =
a = "abc123"
b = "edf456"
lines.insert(0, a)
lines.insert(1, b)
print(lines)
#利用分隔符連線:
s = '\n'.join(lines)
#寫到檔案中去:
with open("test001.txt","w") as z:
z.write(s)
z.close()
#再次讀取檔案中的資料:
with open("test001.txt","r") as x:
data = x.read()
print(data)
x.close()
#清空列表:
# del lines[:]
# print(lines)
第三種的小改方式:
#在列表中插入文字資料:
lines =
lines.insert(0, "aaaa\n")
lines.insert(1, "bbbb\www.cppcns.comn")
print(lines)
#利用分隔符連線:
s = ''.join(lines)
#寫到檔案中去:
with open("test001.txt","w") as z:
z.write(s)
z.close()
#再次讀取檔案中的資料:
with open("test001.txt","r") as x:
data = x.read()
print(data)
x.close()
#清空列表:
# del lines[:]
# print(lines)
本文標題: 對python for 檔案指定行讀寫操作詳解
本文位址: /jiaoben/python/248822.html
讀取檔案指定行linecache
import linecache poem programming is fun when the work is done if you wanna make your work also fun use python f file poem.txt w f.write poem f.close ...
python讀取檔案指定行
import linecache file open 3 2.txt r linecount len file.readlines linecache.getline 3 2.txt linecount 這樣做的過程中發現乙個問題,因為我的指令碼是迴圈讀取3 2.txt檔案,當3 2.txt發生變化...
python檔案IO 讀取指定行
python的標準庫linecache模組非常適合這個任務 import linecache the line linecache.getline d freakout.cpp 222 print the line linecache讀取並快取檔案中所有的文字,若檔案很大,而唯讀一行,則效率低下。可...