Python 三种读文件方法read(), readline(), readlines()及去掉换行符\n
Python 三种读文件方法read(), readline(), readlines()及去掉换行符\n
首先, 让我们看下数据demo.txt
, 就两行数据.
35durant
teamGSW12
1. read()
with open("demo.txt", "r") as f:
data = f.read()
print(data)
print(type(data))
output[1]:
35durant
teamGSW
这种方法直接将所有的数据一次性读取出来, data的数据类型是一个字符串.
2. readline()
with open("demo.txt", "r") as f:
data = f.readline()
print(data)
print(type(data))
output[1]:
35durant
<class 'str'>
该方法读取的是一行内容, 然后是带换行符的, 所有会有空行, 后续会说明如何去掉换行符”\n”.
3. readlines()
with open("demo.txt", "r") as f:
data = f.readlines()
print(data)
print(type(data))
output[1]:
['35durant\n', 'teamGSW']
<class 'list'>
这种方法返回的是一个列表, 注意换行符是包含在字符串的内容中.
接下来说明, 如何在读取文本文件时去掉字符串中的换行符: “\n”.
这里以readlines()方法返回的list与read()方法返回的str为例, 分别进行说明.
方法1: 基于list的索引操作
with open("demo.txt", "r") as f:
data = f.readlines()
print(data)
a = data[0][:-1]
b = data[1]
print(a, b)
output[1]:
['35durant\n', 'teamGSW']
35durant teamGSW
方法2: 基于str的splitlines()方法
with open("demo.txt", "r") as f:
data = f.read().splitlines()
print(data)
output[1]:
['35durant', 'teamGSW']