需求:readlines 如何不要换行符
Python 三种读文件方法read(), readline(), readlines()及去掉换行符\n
首先,让我们看下数据demo.txt
,就两行数据。
35durant
teamGSW
1. read()
这种方法直接将所有的数据一次性读取出来, data的数据类型是一个字符串。
path = "./demo"
with open(path, "r") as f1:
data = f1.read()
print(data)
print("-------------")
print(type(data))
"""
SANY0016 1
SANY0025 1
water 0
-------------
<class 'str'>
"""
2. readline()
该方法读取的是一行内容, 然后是带换行符的, 所有会有空行, 后续会说明如何去掉换行符”\n”。
with open(path, "r") as f2:
data = f2.readline()
print(data)
print("-------------")
print(type(data))
"""
SANY0016 1
(注意,这个位置是换行符\n)
-------------
<class 'str'>
"""
3. readlines()
这种方法返回的是一个列表, 注意换行符是包含在字符串的内容中。
with open(path, "r") as f2:
data = f2.readlines()
print(data)
print("-------------")
print(type(data))
"""
['SANY0016 1\n', 'SANY0025 1\n', 'water 0']
-------------
<class 'list'>
"""
如何在读取文本文件时去掉字符串中的换行符: “\n”。
这里以readlines()方法返回的list与read()方法返回的str为例,分别进行说明。
read()方法读取: 基于str的splitlines()方法
Python splitlines() 按照行(’\r’, ‘\r\n’, \n’)分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。
with open(path, "r") as f4:
data = f4.read().splitlines()
print(data)
"""
['SANY0016 1', 'SANY0025 1', 'water 0']
"""
readlines()方法读取: 基于list的索引操作
with open(path, "r") as f5:
data = f5.readlines()
print(data)
a = data[0][:-1]
b = data[1]
print(a, b)
"""
['SANY0016 1\n', 'SANY0025 1\n', 'water 0']
SANY0016 1 SANY0025 1
"""
参考:
Python 三种读文件方法read(), readline(), readlines()及去掉换行符\n
我的问题:(萌新)??(已解决)
文件夹before中的文件,内容如下:X1,Y1,X2,Y2,CLASS。
我想将其换位,并新建文件,存到after文件夹中,内容如下: CLASS,X1,Y1,X2,Y2。
(如果文件很多直接改位置会比较好)
w+直接把文件内容全部删除了,2条变0条;
r+在文件内容后面追加结果,2条变4条,都不是我想要的。