目录
3、readlines()方法,读取每一行,并将每一行作为元素,返回列表:
一、三种方法的定义区别:
1、read() 不指定参数,读取文件的所有内容;指定参数n,读取前n个字符。
2、readline() 不指定参数,读取指针当前行的内容;指定参数n,读取前n个字符,最多读取当前行的所有内容。
3、readlines() 不指定参数,读取所有内容,只是以列表的形式展现;如果指定参数n,会读取字符总数超过n的行的所有内容。
二、实例代码描述三种方法的区别:
说明:以下代码中使用了readme.txt文件,大家可以任意写一个TXT文件即可。这是我的
hello world!
I love you.
How are you?
0、如何打开文件
# 打开文件
f = open('D:\python_work\interview\mianshi100\\readme.txt', 'r', encoding='utf-8')
print(type(f))
f.close()
# 返回IO文件的格式
# <class '_io.TextIOWrapper'>
# 使用打开文件函数open(),我增加参数encoding=utf-8,
# 否则会报错:'gbk' codec can't decode byte 0x8c in position 20: illegal multibyte sequence
# 打开文件,就需要关闭文件。读取完文件内容就关闭文件。
1、read()方法,读取文件的全部内容:
# read 可以读取文件的全部内容
f = open('D:\python_work\interview\mianshi100\\readme.txt', 'r', encoding='utf-8')
print(f.read()) # 读取文件的全部内容
# print(f.read(2)) # 如果指定参数n,会读取前n个字符
f.seek(6) # 移动指针到n的位置
print(f.read(5))# 读取的内容就从指针的位置开始读取n个字符
f.close()
执行的结果图:
2、readline()方法,读取当前行的内容:
f = open('D:\python_work\interview\mianshi100\\readme.txt', 'r', encoding='utf-8')
print(f.readline()) # 读取当前行的内容
print(f.readline(4)) # 指定参数n,读取第一行的n个字符,
print(f.readline(20)) # 如果指定n超过第一行的字符长度,也只会读取当前行的内容。
f.close()
# 结果如下,每个需要单独测试,因为每测试一个,指针会移动。
# hello world!
# hell
# hello world!
3、readlines()方法,读取每一行,并将每一行作为元素,返回列表:
f = open('D:\python_work\interview\mianshi100\\readme.txt', 'r', encoding='utf-8')
print(f.readlines())
print(f.readlines(3)) # 如果指定参数n,n的个数不超过当前行的字符个数,所以只展示当前行的内容
print(f.readlines(13)) # 如果指定参数n,n的个数超过当前行的字符个数,就会展示下一行的数据。
f.close()
# 结果如下,每个需要单独测试,因为每测试一个,指针会移动。
# ['hello world!\n', 'I love you.\n', 'How are you?']
# ['hello world!\n']
# ['hello world!\n', 'I love you.\n']