1. 程式人生 > >python for 檔案指定行讀寫操作

python for 檔案指定行讀寫操作

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.readline([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') as 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\n")
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)

備註:第一種方式,比較生硬,不推薦。第二種方式可以反覆追加內容,第三種方式只追加一次,不會重複。