1.Python,write()和writelines()的區別
f = open("a.txt", 'a')
f.write("write寫入一行新數據")
f.write("write寫入一行新數據")
f.write("write寫入一行新數據")
f.writelines("writelines寫入一行新數據")
f.writelines("writelines寫入一行新數據")
f.close()
''' 輸出結果是: write寫入一行新數據write寫入一行新數據write寫入一行新數據write寫入一行新數據write寫入一行新數據write寫入一行新數據writelines寫入一行新數據writelines寫入一行新數據 '''
#(1)使用 writelines() 函數向文件中寫入多行數據時,不會自動給各行添加換行符。所以上面看到的依然是沒有換行的
#(2)注意,寫入函數只有 write() 和 writelines() 函數,而沒有名爲 writeline 的函數。
#(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
參考http://c.biancheng.net/view/2544.html
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