python3中,讀取文件有三種方法:read()、readline()、readlines()。 此三種方法,均支持接收一個變數,用於限制每次讀取的數據量,但是,通常不會使用。 本文的目的:分析、總結上述三種讀取方式的使用方法及特點。 一、read方法 特點:讀取整個文件,將文件內容放到一個字元串 ...
python3中,讀取文件有三種方法:read()、readline()、readlines()。
此三種方法,均支持接收一個變數,用於限制每次讀取的數據量,但是,通常不會使用。
本文的目的:分析、總結上述三種讀取方式的使用方法及特點。
一、read方法
-
特點:讀取整個文件,將文件內容放到一個字元串變數中。
-
缺點:如果文件非常大,尤其是大於記憶體時,無法使用read()方法。
file = open('部門同事聯繫方式.txt', 'r') # 創建的這個文件,是一個可迭代對象
try:
text = file.read() # 結果為str類型
print(type(text)) #列印text的類型
print(text)
finally:
file.close() #關閉文件file
"""
<class 'str'>
李飛 177 70 13888888
王超 170 50 13988888
白凈 167 48 13324434
黃山 166 46 13828382
"""
read()直接讀取位元組到字元串中,包括了換行符
>>> file = open('兼職模特聯繫方式.txt', 'r')
>>> a = file.read()
>>> a
'李飛 177 70 13888888\n王超 170 50 13988888\n白凈 167 48 13324434\n黃山 166 46 13828382'
二、readline方法
-
特點:readline()方法每次讀取一行;返回的是一個字元串對象,保持當前行的記憶體
-
缺點:比readlines慢的多
file = open('部門同事聯繫方式.txt', 'r')
try:
while True:
text_line = file.readline()
if text_line:
print(type(text_line), text_line)
else:
break
finally:
file.close()
"""
<class 'str'> 李飛 177 70 13888888
<class 'str'> 王超 170 50 13988888
<class 'str'> 白凈 167 48 13324434
<class 'str'> 黃山 166 46 13828382
"""
readline()讀取整行,包括行結束符,並作為字元串返回
>>> file = open('兼職模特聯繫方式.txt', 'r')
>>> a = file.readline()
>>> a
'李飛 177 70 13888888\n'
三、readlines方法
特點:一次性讀取整個文件;自動將文件內容分析成一個行的列表
'''
學習中遇到問題沒人解答?小編創建了一個Python學習交流群:711312441
尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學習教程和PDF電子書!
'''
file = open('部門同事聯繫方式.txt', 'r')
try:
text_lines = file.readlines()
print(type(text_lines), text_lines)
for line in text_lines:
print(type(line), line)
finally:
file.close()
"""
<class 'list'> ['李飛 177 70 13888888\n', '王超 170 50 13988888\n', '白凈 167 48 13324434\n', '黃山 166 46 13828382']
<class 'str'> 李飛 177 70 13888888
<class 'str'> 王超 170 50 13988888
<class 'str'> 白凈 167 48 13324434
<class 'str'> 黃山 166 46 13828382
"""
readlines()讀取所有行,然後把它們作為一個字元串列表返回。
>>> file = open('兼職模特聯繫方式.txt', 'r')
>>> a = file.readlines()
>>> a
['李飛 177 70 13888888\n', '王超 170 50 13988888\n', '白凈 167 48 13324434\n',
'黃山 166 46 13828382']