對python for 檔案指定行讀寫操作詳解

2022-10-04 18:24:11 字數 4049 閱讀 8307

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讀取並快取檔案中所有的文字,若檔案很大,而唯讀一行,則效率低下。可...