讀取文件的三個方法:read()、readline()、readlines()。都可接受一個變量用以限制每次讀取的數據量,但一般不使用。本章目的是分析和總結三種讀取方式的使用方法和特色。spa
特色是:讀取整個文件,將文件內容放到一個字符串變量中。code
劣勢是:若是文件很是大,尤爲是大於內存時,沒法使用read()方法。對象
file = open('兼職模特聯繫方式.txt', 'r') # 建立的這個文件,也是一個可迭代對象 try: text = file.read() # 結果爲str類型 print(type(text)) print(text) finally: file.close() """ <class 'str'> 吳迪 177 70 13888888 王思 170 50 13988888 白雪 167 48 13324434 黃蓉 166 46 13828382 """
read()直接讀取字節到字符串中,包括了換行符blog
>>> file = open('兼職模特聯繫方式.txt', 'r') >>> a = file.read() >>> a '吳迪 177 70 13888888\n王思 170 50 13988888\n白雪 167 48 13324434\n黃蓉 166 46 13828382'
特色: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() 讀取整行,包括行結束符,並做爲字符串返回class
>>> file = open('兼職模特聯繫方式.txt', 'r') >>> a = file.readline() >>> a '吳迪 177 70 13888888\n'
特色:一次性讀取整個文件;自動將文件內容分析成一個行的列表。變量
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
>>> file = open('兼職模特聯繫方式.txt', 'r') >>> a = file.readlines() >>> a ['吳迪 177 70 13888888\n', '王思 170 50 13988888\n', '白雪 167 48 13324434\n', '黃蓉 166 46 13828382']