【python基礎】python文件操做最重要的我的總結

1.Python,write()和writelines()的區別html


f = open("a.txt", 'a')python

f.write("write寫入一行新數據")ide

f.write("write寫入一行新數據")函數

f.write("write寫入一行新數據")學習

f.writelines("writelines寫入一行新數據")測試

f.writelines("writelines寫入一行新數據")spa

f.close().net

'''
輸出結果是:
write寫入一行新數據write寫入一行新數據write寫入一行新數據write寫入一行新數據write寫入一行新數據write寫入一行新數據writelines寫入一行新數據writelines寫入一行新數據
'''

#(1)使用 writelines() 函數向文件中寫入多行數據時,不會自動給各行添加換行符。因此上面看到的依然是沒有換行的orm

#(2)注意,寫入函數只有 write() 和 writelines() 函數,而沒有名爲 writeline 的函數。htm


#(3)那麼Python,write()和writelines()有什麼區別呢?參見https://blog.csdn.net/Zhongjie1986/article/details/91448373

'''

file.write(str)的參數是一個字符串,就是你要寫入文件的內容.

file.writelines(sequence)的參數是序列,好比列表,它會迭代幫你寫入文件。固然writelines()函數的參數也能夠是一個字符串,用法跟write()函數相似。

'''

f = open("b.txt", 'a')

#f.write(['hello','how','a'])       #f.write(['hello','how','a'])報錯:TypeError: write() argument must be str, not list

f.writelines(['hello\n','how','a'])

f.close()


#(4)注意,在使用 write() 向文件中寫入數據,需保證使用 open() 函數是以 r+、w、w+、a 或 a+ 的模式打開文件,

# 不然執行 write() 函數會拋出 io.UnsupportedOperation 錯誤。參考open時候的模式

#(5)總結通常咱們須要寫入文件時候,就有write()就好了,除非有特殊序列要寫的,能夠考慮下writelines()


2.open()學習mode指定了文件的打開模式

參考https://baijiahao.baidu.com/s?id=1618831950256096192&wfr=spider&for=pc

image.png

參考http://c.biancheng.net/view/2544.html

image.png

3.r+和w+都是以讀寫方式來打開文件。r+和w+方式不一樣之處

#a.txt和a2.txt裏面內容都是123456789 r+和w+都是以讀寫方式來打開文件。如今來比較r+和w+方式不一樣之處
f = open("a.txt", 'r+')
f2 = open("a2.txt", 'w+')

f.write("xxh")
f2.write("xxh")

f.close()
f2.close()

'''
得出的結果 a.txt裏面內容由123456789變成了xxh456789
            a2.txt裏面內容由123456789變成了xxh
            
因此r+和w+都是以讀寫方式來打開文件。r+和w+方式不一樣是 
r+ (讀寫方式),打開文件後,既能夠從頭讀取文件內容,也能夠從開頭向文件中寫入新的內容,寫入的新內容會覆蓋文件中等長度的原有內容。
w+ (讀寫方式),打開文件後,會對原有內容進行清空,並對該文件有讀寫權限。 

'''

也就是說w+必定會先清空文本內全部內容,再給你讀寫這個文件名!下面用readlines也測試了一下,發現真的是w+打開open文件以後,你想readlines發現已經空了,讀取不出來了!

'''
a.txt和a2.txt裏面內容都是
123456789
987
654
321

# r+和w+都是以讀寫方式來打開文件。如今來比較r+和w+方式不一樣之處
'''
f = open("a.txt", 'r+')
f2 = open("a2.txt", 'w+')



print(f.readlines())
print(f2.readlines())


f.close()
f2.close()

'''
得出的結果
['123456789\n', '987\n', '654\n', '321']
[]


'''


4.open(filename,mode)其中filename能夠是目錄+文件名或者直接文件名

直接文件名即當一個須要打開的文件名稱不帶路徑時,open函數會在Python程序運行的當前目錄尋找該文件!



5.python讀取文件的幾個函數read()和readline()和readlines()區別。

read()按字節(字符)讀取文件

readline()和readlines()函數:按行讀取文件(其中 readline() 函數用於讀取一行內容,而 readlines() 函數用於讀取文件內的全部行。)



(1)使用 read() 函數讀取文件時,若是文件過大,則一次讀取所有內容到內存,容易形成內存不足,而相比每次限制讀取字符(或字節)的個數,更推薦你們使用逐行讀取文件的方式。

(2)read()裏面能夠加一個size,果省略,則默認一次性讀取全部內容。

'''
a.txt裏面內容
123456789
987
654
321
'''
f = open("a.txt", 'r+')
print(f.readline())
f.close()

----------------------------------------
輸出是
123456789

----------------------------------------




f = open("a.txt", 'r+')
print(f.readlines())
f.close()

----------------------------------------
輸出是
['123456789\n', '987\n', '654\n', '321']

----------------------------------------


f = open("a.txt", 'r+')
print(f.read())
f.close()

----------------------------------------
輸出是
123456789
987
654
321
----------------------------------------


f = open("a.txt", 'r+')
print(f.read(1))
f.close()

----------------------------------------
輸出是
1
----------------------------------------


看上面,咱們看到readlines輸出是序列,每一行做爲序列的一個元素,因此咱們通常讀取文件都是用f.readlines()來,以後用for循環遍歷序列,以下:

for words in f.readlines():
    print(words)
    
輸出是:
123456789

987

654

321
相關文章
相關標籤/搜索