这几天做程序作业的时候需要用python的读取文件功能,在我用readlines()函数做逐行读取的时候遇到了一个小问题,在这里和大家分享一下。
txt文件里的内容是这样的:
1 1 2 2 3 3 4 4 5 5
代码也没什么问题:
1 with open('001.txt','r') as f: 2 lines = f.readlines() 3 for line in lines: 4 print(line)
但运行出来就。。。:
1 1 2 3 2 4 5 3 6 7 4 8 9 5
每两行之间都出现了奇怪的空行,这是怎么回事呢?
其实是因为文件中每行末尾会有一个隐藏的换行符“\n”,读取之后“\n”会被解析出来形成换行,而print()语句本身就自带换行的效果,两个换行叠加之后就会出现空行。
那么怎样消除这个bug呢?
其实很简单,python有两个自带的函数:.strip()和.rstrip()
- .strip()的意思是消除字符串整体的指定字符
- .rstrip()的意思是消除字符串末尾的指定字符
括号里什么都不写,默认消除空格和换行符
ok,我们再来试试:
1 with open('001.txt','r') as f: 2 lines = f.readlines() 3 for line in lines: 4 print(line.strip())
运行结果:
1 1 2 2 3 3 4 4 5 5
问题解决!