python逐行读取txt文件时出现多余空行的问题

这几天做程序作业的时候需要用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

问题解决!

 

转载于:https://www.cnblogs.com/bgd150809114/p/9222177.html

你可能感兴趣的:(python,大数据)