Python一次性读取文件的所有内容在《【Python】文件读写操作》(点击打开链接)中已经说明过的,但有些时候,需要对文件中的每一行进行处理。
比如有一个f:\1.txt如下:
此时,如果要按行读取这个文件,可以直接利用Pyhon的for循环来读取,其中for的对象是这个文件指针,代码如下:
file_path="f:\\a.txt" fp=open(file_path,"a+"); for eachline in fp: print eachline.rstrip(); fp.close();运行效果如下:
这里的eachline就是每一行的内容,后面的rstrip()方法是用来消除\n字符的,让print的打印美观,更重要的是让你的eachline变量不是以\n结尾。如果没有rstrip()的话,上述的程序的运行结果就会变成以下的样子。这里的strip()相当于Java、C#中的trim()方法。strip是trim掉字符串两边的空格、换行符等。lstrip是trim掉左边的空格、换行符等,rstrip,是trim掉右边的掉左边的空格、换行符等,反正就是搞掉空白的东西。
同时,还要注意的文件路径,虽然在Python中写成file_path="f:\a.txt",PyDev编译器不会报错,但是在运行时,会出现如下的[Errno 22] invalid mode (‘a+‘) or filename的错误,所以你还是应该写成file_path="f:\\a.txt",不然Python就会把\a转化成不知道什么东西了。
版权声明:本文为博主原创文章,未经博主允许不得转载。
【Python】按行读取文件、IOError: [Errno 22] invalid mode ('a+') or filename,处理文件的换行符
原文地址:http://blog.csdn.net/yongh701/article/details/47147005